位置: 编程技术 - 正文

面向对象的编程思想在javascript中的运用上部(面向对象的编程语言更适合大规模编程)

编辑:rootadmin
其实,面向对象的思想是独立于编程语言的,例如在C#中,在一个静态类的静态方法中,按照过程式开发调用一系列静态函数,我们很难说这是面向对象的编程,相反,象jquery和extjs这样优秀的javascript库,却处处体现着面向对象的设计思想。本文不打算探讨javascript是否能够算做面向对象的编程语言,这个问题是重视中国式考试的人应该关注的,我这里只是简单的说明如何在javascript中使用面向对象的编程思想。 面向对象首先要有对象。在javascript中创建一个对象非常简单: 这样就产生了一个对象,我们可以很方便的给这个对象添加属性和方法: 不过大多数人还是习惯把对象的属性和方法放在定义对象的一对{}里边: 访问属性和方法有两种方式,第一种: 这种写法很常见,C#中调用对象的属性和方法也是这种方式。还有一种是javascript中比较特别的,使用属性或者方法的名字作为索引来进行访问: 这好像有点和孔乙己“茴香的茴字有几种写法”差不多了,事实上,很少有人使用索引来调用对象的属性或者方法。 除了我们自定义的属性和方法,我们的对象还有一个constructor属性以及toString()等方法。这些属性和方法是从Object内置对象来的,所有的对象都会有这些属性和方法。其中constructor属性指向构造出该对象的构造函数。我们没有使用构造函数来创建对象,事实上,js的解释器会使用Object构造函数。如果我们自己定义了构造函数,那么便可以通过该构造函数来创建对象,这样可以使得创建的对象具有相同的属性和方法,这便开始有点面向对象的味道了。好,我们从一个简单的例子开始看看如何创建一个构造函数吧: 我们定义了一个名字叫Person的构造函数,该构造函数有三个属性和一个方法,通过构造函数来产生一个对象并调用方法也非常简单: 运行后我们可以看到弹出一个对话框,显示出这个叫张三的人的信息: 我们还可以看看对象的constructor属性来看看zhangsan的构造函数是不是我们定义好的Person: 结果如图: 可以看到,正是我们的Person构造函数。 不过,这里还是有点问题,每一次我们构造一个对象,都会在内存中为属性和方法分配内存空间,而事实上,所有的对象完全可以用同一个方法,并不需要有多个方法的副本,这样有些浪费内存空间。既然意识到了这个问题,让我们来想想如何解决吧。一个很自然的想法是,既然我们只想为方法分配一次内存空间,那么我们可以设置一个值用来标识方法的内存空间是否已经分配,按照这个思路,我们将构造函数做如下修改: 这里,我们用一个成员_initialized来指示是否已经对方法进行了内存空间的分配。当第一个对象构造的时候_initialized未被定义,所以我们的判断语句为真,这时会对方法进行了定义并分配内存空间,然后把_initialized的值设置为true,用以表明方法的内存空间已经分配了。第二个对象构造的时候则不会再进入判断,因而也不会再一次分配内存空间。似乎没什么问题,运行一下看看,张三的信息依然正常显示。虽然不辛苦,不过解决了一个小问题,还是庆祝下吧,来盘回锅肉,我要大快朵颐。还没开吃,一个叫李四的MM也想让电脑弹出她的个人信息。OK,很简单,再构造一个对象,然后调用showInfo方法就可以了: 为了照顾MM,还把这段放在了张三的前边。MM的信息正确显示出来了,可是张三的资料不见了。这下张三不乐意了,排名放在MM后边也罢了,但好歹得有名字啊。这可苦了我这编程人员,回锅肉看来没办法吃了,先改bug吧。打开firebug,看到MM的信息显示之后出现错误,提示为:zhangsan.showInfo is not a function。设置断点看看,构造zhangsi对象以后发现并没有showInfo这个方法。原来showInfo方法虽然只有一个,但是存在于第一个对象之中,第二个对象并不能访问。那么,究竟如何才能让同一个构造函数产生的对象共用同一个函数呢?javascript中的prototype给我们提供了这个功能。根据javascript的规范中描述,每一个构造函数都有一个prototype属性用于实现继承和属性的共享。我们的showInfo方法也可以看作是一个属性,该属性指向一个函数的引用。现在我们使用prototype来使得我们的方法可以共享,代码的改动很简单,把this.showInfo改成Person.prototype.showInfo就可以了,改动之后的代码如下: 使用该构造函数生成两个对象: 运行之后先显示李四的信息,然后是张三的信息。现在两个人都满意了,可惜我的回锅肉已经凉了

推荐整理分享面向对象的编程思想在javascript中的运用上部(面向对象的编程语言更适合大规模编程),希望有所帮助,仅作参考,欢迎阅读内容。

面向对象的编程思想在javascript中的运用上部(面向对象的编程语言更适合大规模编程)

文章相关热门搜索词:面向对象的编程方法的英文缩写是,面向对象的编程语言有哪些,面向对象的编程方法,面向对象的编程方法,面向对象的编程方法的英文缩写是,面向对象的编程思路,面向对象的编程思路,面向对象的编程思路,内容如对您有帮助,希望把文章链接给更多的朋友!

JS小框架 fly javascript framework 框架选择器部分兼容浏览器原生的查询语法,和jQuery大部分选择器,选择器部分文档大部分来自jQeruyAPI特点,选择器支持lambda表达式文件打包下载

JS类的封装及实现代码 1.定义js类js并不是一种面向对向的语言,没有提供对类的支持,因此我们不能像在传统的语言里那样用class来定义类,但我们可以利用js的闭包封装机制来实

javascript 面向对象全新理练之数据的封装 今天主要讨论如何在JavaScript脚本中实现数据的封装(encapsulation)。数据封装说的简单点就是把不希望调用者看见的内容隐藏起来。它是面向对象程序设

标签: 面向对象的编程语言更适合大规模编程

本文链接地址:https://www.jiuchutong.com/biancheng/386509.html 转载请保留说明!

上一篇:Riot.js 快速的JavaScript单元测试框架(java script js)

下一篇:JS小框架 fly javascript framework(js框架开发实例)

  • 商业保险进项税额转出影响成本吗
  • 车辆购置税完税证明是什么
  • 文化建设费征收依据
  • 金税盘电子发票怎么读入
  • 委托开发的定义
  • 总公司汇总缴纳所得税升为一般纳税人分公司受影响吗
  • 销项税额转出减去还是加上
  • 境外增值税代扣代缴
  • 钻井勘探支出已费用化的探井
  • 个人所得税办理退税需要什么资料和手续
  • 借用另一家公司名义
  • 工程公司后期维保费用如何入账?
  • 税控设备全额抵扣政策
  • 增值税发票增量流程网上怎么申请
  • 房地产开发企业会计科目
  • 会计人员必备的知识和技能
  • 财产保险费发票税率
  • 重点税源表怎么自动取数
  • 代收代缴消费税要交城建税吗?
  • 委托出口货物怎么办理退免税?
  • 公司零报税需要会计吗
  • 保险车辆折旧的计算方法有哪些
  • 付款网站制作
  • 如何在windows11上打开蓝牙
  • 常见内存大小
  • 科技推广和应用服务业
  • 预提费用年终有余额怎么办
  • 企业转让股票交什么税费呢
  • linux设置权限规则
  • 所得税如何做帐
  • ftp pwd命令
  • php null false
  • 多提附加税跨年怎么计算
  • 没有购入发票可以开出发票
  • 微信小程序前端源码
  • 解决的英文
  • 采用公允价值模式计量的投资性房地产处置
  • php模板引擎语法
  • fsck命令详解
  • 收到事业单位分红怎么办
  • 库存周转率会大于1吗
  • 坏账准备的会计分录怎么写
  • 核定征收的收入
  • 简易征收的进项税怎么处理
  • mysql5.7.32安装
  • 销售公司提成表模板
  • 工业企业库存商品的初始入账成本
  • sql表添加字段
  • 坏账核销的会计规定
  • 新办公司实收资本怎么算
  • 微信,支付宝等第三方支付对货币的影响
  • 航天税盘服务费开的普票可以抵税吗
  • 赔偿给客户的产品交增值税吗
  • 部门召开会议
  • 管理费用抵消分录
  • 哪些个体户要报残保金
  • 建筑企业总公司施工可否由分公司开发票
  • 减免的费用怎么做账
  • 劳动纠纷给员工的建议
  • 发票专用章刻制
  • sql合并字段
  • 微软发布linux
  • win10预览版退回正式版
  • macbook 手写
  • freebsd 添加用户
  • ora01804怎么解决windows
  • 无线网络找不到证书
  • centos关闭开机启动项
  • “explorer.exe”进程文件
  • 从哪里看windows是多少位的
  • opengl 投影矩阵
  • 简述opengl的编程步骤
  • js object.seal
  • perl计算时间差
  • jquery 引入js
  • 添加ie
  • jquery img onload
  • javascript面向对象精要pdf
  • 退休军人免门票吗
  • 个人所得税申报是什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设