位置: 编程技术 - 正文

面向对象的编程思想在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框架开发实例)

  • 我国企业基本所得税的税率
  • 税筹是什么意思,有哪些工具
  • 应收账款贷方余额怎么调平
  • 员工在外出差的说说
  • 兼职合同工资发放
  • 企业出包工程预付的工程款
  • 电子税务局税种核定怎么操作
  • 非居民工资薪金个人所得税计算方法
  • 什么叫应纳税额什么与什么的比率叫做税率
  • 未取得支付工程款的发票怎么做账?
  • 未计提职工教育经费汇算清缴
  • 公司给员工的奖品是否要扣税
  • 所得税汇算清缴补税的会计处理
  • 生产型企业增值税率是多少
  • 国税2016年第53号公告解读
  • 会计核算中利润包括哪些
  • 公司办事处人员配置标准最新
  • 房租费属于无形资产吗
  • 个体户财务章必须刻吗
  • 什么样的公司可以交五险一金
  • 修叉车这个工作怎么样
  • 收到工程发票如何做账
  • 往年亏损,今年盈利,是否计提盈余公积
  • 存贷款基准利率和lpr
  • 关闭固定在任务栏的功能
  • 应交消费税会计分录怎么做
  • 融资租入固定资产是什么意思
  • 固定资产自行建造的会计处理
  • 自创商誉可确认为商誉且在资产负债表中列报
  • 销售发票重复开,库存商品怎么处理?
  • 代扣代缴企业所得税如何申报
  • 固定资产处理步骤
  • 代订机票发票可以入账吗
  • php jsondecode
  • zentaophp框架
  • php显示错误报告方式
  • b站导出预设
  • Win11 KB5025239 / KB5025224 累积更新今日发布
  • 一个残疾证一年单位免多少税2023
  • 企业退税要用税吗
  • 合伙结算转借款
  • 油气勘探开发
  • 增值税专用发票几个点
  • 织梦官方
  • 无退税产品出口征税
  • 预付账款购进原材料怎么做账
  • 罚款支出计入什么费用
  • 房地产开发企业增值税税率
  • 广告公司工程部
  • 经营范围中没有这个项目开票后果
  • 出纳去银行存现
  • 委托加工存货收回后直接用于销售的账务处理
  • 预付款开了增值税专票怎么办
  • 收到返利怎么做会计分录
  • 出口抵减内销产品应纳税额在借方
  • 社保如何做分录报销
  • 公司增资怎么处理
  • 管道固定装置
  • 确认医院体检收费怎么办
  • mysql中的limit用法有哪些(推荐)
  • 一条的句子怎么写
  • win10隐藏设置
  • windrv.exe
  • 苹果发布会亮点速览
  • linux限速
  • windows语音识别
  • 将list转换为json字符串
  • ms-sys
  • 从零开始学什么技术
  • 使用jquery
  • 使用jquery实现的项目
  • 德州市税务局领导
  • 上海各区税务大厅
  • 党建引领安全宣传美篇幼儿园
  • 国家税务总局广州市税务局
  • 税务 信息
  • 亳州国税局电话号码
  • 去地税开个人发票
  • 税务有哪些方面
  • 吉林省职称查询入口
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设