位置: 编程技术 - 正文

JS面向对象编程详解(js面向对象编程思想)

编辑:rootadmin

推荐整理分享JS面向对象编程详解(js面向对象编程思想),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js面向对象编程实例,js中面向对象编程,js面向对象写法,js中面向对象编程,js面向对象编程思想,js面向对象编程思想,js面向对象编程实例,js面向对象编程实例,内容如对您有帮助,希望把文章链接给更多的朋友!

序言  在JavaScript的大世界里讨论面向对象,都要提到两点:1.JavaScript是一门基于原型的面向对象语言 2.模拟类语言的面向对象方式。对于为什么要模拟类语言的面向对象,我个人认为:某些情况下,原型模式能够提供一定的便利,但在复杂的应用中,基于原型的面向对象系统在抽象性与继承性方面差强人意。由于JavaScript是唯一一个被各大浏览器支持的脚本语言,所以各路高手不得不使用各种方法来提高语言的便利性,优化的结果就是其编写的代码越来越像类语言中的面向对象方式,从而也掩盖了JavaScript原型系统的本质。  

基于原型的面向对象语言  原型模式如类模式一样,都是是一种编程泛型,即编程的方法论。另外最近大红大紫的函数编程也是一种编程泛型。JavaScript之父Brendan Eich在设计JavaScript时,从一开始就没打算为其加入类的概念,而是借鉴了另外两门基于原型的的语言:Self和Smalltalk。

  既然同为面向对象语言,那就得有创建对象的方法。在类语言中,对象基于模板来创建,首先定义一个类作为对现实世界的抽象,然后由类来实例化对象;而在原型语言中,对象以克隆另一个对象的方式创建,被克隆的母体称为原型对象。

  克隆的关键在于语言本身是否为我们提供了原生的克隆方法。在ECMAScript5中,Object.create可以用来克隆对象。

  原型模式的目的并不在于得到一个一模一样的对象,而提供了一种便捷的方式去创建对象(出自《JavaScript设计模式与开发实践》)。但是由于语言设计的问题,JavaScript的原型存在着诸多矛盾,它的某些复杂的语法看起来就那些基于类的语言,这些语法问题掩盖了它的原型机制(出自《JavaScript语言精粹》)。如:

  实际上,当一个函数对象呗创建时,Function构造器产生的函数对象会运行类似这样的一些代码:

  新的函数对象被赋予一个prototype属性,它的值是一个包含constructor属性且属性值为该新函数的对象。当对一个函数使用new运算符时,函数的prototype的属性的值被作为原型对象来克隆出新对象。如果new运算符是一个方法,它的执行过程如下:

  从上面可以看出,虽然使用new运算符调用函数看起来像是使用模板实例化的方式来创建对象,但本质还是以原型对象来克隆出新对象。

JS面向对象编程详解(js面向对象编程思想)

  由于新克隆的对象能否访问到原型对象的一切方法和属性,加上new运算符的特性,这便成了利用原型模拟类式语言的基石。

利用原型模拟类式语言抽象

  用原型模式来模拟类,首先是抽象方式。根据JavaScript语言的特点,通常一个类(实际上是伪类)通常是将字段放置于构造函数(实际上是new 运算符调用的函数,JavaScript本身并没有构造函数的概念)中,而将方法放置于函数的prototype属性里。

继承

  继承是OO语言中的一个最为人津津乐道的概念。许多OO语言都支持两种继承方式:接口继承和实现继承。接口继承之继承方法签名,而实现继承则继承实际的方法。但是ECMAScript中无法实现接口继承,只支持实现继承,而且其实现继承主要是依靠原型链来实现的。(出自《JavaScript高级程序设计》 6.3节——继承)在高三中作者探索了各种关于继承的模拟,如:组合继承、原型继承、寄生继承、寄生组合继承,最终寄生组合式成为所有模拟类式继承的基础。

  高三中只给出了单继承的解决方案,关于多继承的模拟我们还得自己想办法。由于多继承有其本身的困难:面向对象语言如果支持了多继承的话,都会遇到著名的菱形问题(Diamond Problem)。假设存在一个如左图所示的继承关系,O中有一个方法foo,被A类和B类覆写,但是没有被C类覆写。那么C在调用foo方法的时候,究竟是调用A中的foo,还是调用B中的foo?

  所以大多数语言并不支持多继承,如Java支持单继承+接口的形式。JavaScript并不支持接口,要在一个不支持接口的语言上去模拟接口怎么办?答案是著名的鸭式辨型。放到实际代码中就是混入(mixin)。原理很简单:

  值得一提的是dojo利用MRO(方法解析顺序(Method Resolution Order),即查找被调用的方法所在类时的搜索顺序)方式解决了多继承的问题。  

  到此,我们已经清楚了模拟类语言的基本原理。作为一个爱折腾的程序员,我希望拥有自己的方式来简化类的创建:

提供一种便利的方式去创建类,而不暴露函数的prototype属性 在子类中覆盖父类方法时,能够像Java一样提供super函数,来直接访问父类同名方法 以更方便的方式添加静态变量和方法而不去关心prototype 像C#那样支持Attribute   

最终,在借鉴各位大牛的知识总结,我编写了自己的类创建工具O.js:

类创建方式如下:

继承:

标签: js面向对象编程思想

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

上一篇:JS判断字符串字节数并截取长度的方法(js判断字符串字符出现的次数)

下一篇:JavaScript中获取纯正的undefined的方法(javascript中获取字符串长度)

  • 金税盘是什么时候开始使用的
  • 税务局三师有什么用
  • 利息税怎么算的
  • 出口退税计算公式 中华会计网校
  • 新准则经营租赁会计分录
  • 企业奖金会计分录
  • 单位参加社保必须全员全额申报吗
  • 商业用房出租税率是多少
  • 民间非营利机构加班费记什么科目
  • 贷款受托支付可以给股东吗
  • 母公司捐赠资金给子公司
  • 土地增值税清算是什么意思
  • 福利费进项税可以抵扣
  • 年度结转之前需要做什么
  • 房地产退房款会计分录
  • 产品质量赔款的账务处理
  • 非税收入通用票据需要盖章吗
  • 核定征收的小微企业企业所得税计算
  • 营改增后房地产开发税费一览表
  • 药用植物所
  • 从事非学历教育的学校提供的教育服务免征增值税吗
  • 借库存商品贷生产成本这笔会计分录反映的经济业务是
  • 进料加工料件需补税的情况
  • 企业购买自行车记账什么科目
  • 小规模应交税费有三级科目吗
  • 网络服务费一般纳税人几个点
  • 新版edge浏览器兼容ie
  • 公司注销登记提交材料规范
  • 腾讯电脑管家中的软件市场打不开
  • win10如何查看显卡配置
  • Win10版本21H2卡死
  • 代垫费用的进项怎么抵扣
  • 福利性分配举例
  • 交完社保
  • 不能进行加计扣除的研发费用有哪些
  • php 自动化测试
  • ci框架教程
  • 盈余公积转增资本的最高限额
  • AIGC之GPT-4:GPT-4的简介(核心原理/意义/亮点/技术点/缺点/使用建议)、使用方法、案例应用(计算能力/代码能力/看图能力等)之详细攻略
  • phpgd库怎么开
  • 租赁汽车折旧年限怎么算
  • 实收资本的会计处理
  • 劳务派遣服务是收派服务吗
  • 费用化支出需要摊销吗
  • css文件代码示例
  • 开专票一定要写明细吗
  • 纳税调整调减有哪些
  • 补缴以前年度的印花税会计分录
  • 减免税款属于政府补助利得吗
  • 工商年报纳税总额从哪看
  • 其他综合收益什么情况下转入留存收益
  • 影响营业利润和利润总额的因素
  • 企业会计准则第4号固定资产
  • mysql多表查询方式
  • 如何解决windows10数据放到国外进行处理
  • centos6 rpm
  • 没有光驱有什么影响
  • wincomm.exe - wincomm是什么进程
  • win10 sp3
  • 怎么学linux
  • win8怎么把网速调到最快
  • virtualbox怎么打开虚拟机
  • win8系统保护已关闭 如何系统还原
  • js的上传文件
  • javascript数据结构与算法第三版
  • 网页制作颜色搭配
  • Unity3D游戏开发引擎
  • unity碰撞得分代码
  • 使用jquery操作dom
  • dos命令不能执行怎么回事
  • 常用的js框架有哪些
  • javascript之typeof、instanceof操作符使用探讨
  • node.js中使用文件流进行文件复制,首先需要创建一个
  • android studio乱码怎么解决
  • unity uGUI按钮点击换图
  • 游戏客服怎么跟客户聊天
  • python toad
  • 税务局网上缴税
  • ca用户绑定怎么绑
  • 船舶吨税是中央税还是地方税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设