位置: 编程技术 - 正文

javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)(js中的类是什么)

编辑:rootadmin

关于javascript中类的继承可以参考阮一峰的Blog《Javascript继承机制的设计思想》,说的很透。

一、在javascript中实例化遇到的问题:

下面用《javascript高级程序设计》中的例子来做说明,假如现在定义了一个car的对象,它是Object类的实例。像下面这样的: 现在又需要这样的一个实例,你可能会像这样来定义: 这样遇到的问题是每个对象都需要重新定义一次他的字段和方法。很麻烦。 二、类的定义--工厂方式实现: 对上面的例子进行一个包装,利用函数的返回值来做文章: 调用方式: var oCar1 = createCar(); var oCar2 = createCar(); 这种方式被称之为工厂方式。工厂方式看起来是省事多了。起码创建一个对象的时候不再需要那么多的行数。因为每个属性(color,doors,mpg)的值都是固定的,还需要再次进行改造,利用参数传递来实现: 这样做看似的确可以实现了对象了。实现也很简单,调用也很方便。但是有两个不是很好的地方: 1、从语义上看,在创建对象时没有使用new运算符,似乎不是那么正规(通常创建一个对象都用一个new运算符来实现)。 2、不符合面向对象的特征--封装。在这个例子中,oCar1和oCar2都有自己的showColor方法,并且他们的showColor都是自己的实现。但是事实是他们共享的是同一个函数。 也是有办法解决这个共享函数的问题,利用函数指针来解决。在createCar函数之外再创建一个showColor函数,而oTempCar的showColor方法指向这个showColor函数: 虽然这样解决了重复创建函数的问题,但这样的话,就使showColor函数看起来不像是对象的方法。 三、类的定义--构造函数方式实现: 在Car类中,this指针代表了Car的一个实例,因此不需要返回值。虽然构造函数方式实现了类的定义,但是和工厂方式一样,他也是为每个实例创建一个单独的方法。虽然可以像工厂函数一样在函数之外再创建一个函数利用指针来解决这个问题,但是这么做的话,在语义上没有意义。 四、类的定义--原型方式实现: 利用对象的prototype属性,把它看成是创建新对象所依赖的原型。用空构造函数来设置类名。然后所有的属性和方法都被直接赋予prototype属性。 1、构造函数没有参数。使用原型时,不能通过给函数参数传递参数来初始化属性值。 2、在有多个实例时,对其中一个实例的属性的更改会影响到另外一个实例的属性。 测试代码: 当然了,也会有办法解决这个问题的。那就是混合的构造函数/原型方式 五、类的实现--混合的构造函数/原型方式实现 这种实现方式是将每个类的实例中共享的属性或者方法妨到原型链中实现,而将不需要共享实现的属性和方法放在构造函数中实现。这中类的实现方式是使用最广泛的方式。 这种方式和混合的构造函数/原型方式相比,提供了一种友好的编程风格(在混合的构造函数/原型方式中,showColor方法的定义是在方法体外实现的,而不是在构造函数的方法体内完成的)。这种类的定义方式使用也很多。 七、类的定义--混合工厂方式实现 这种方式和工厂方式看起来差不多。由于在Car()构造函数内部调用了new运算符,所以将忽略掉位于构造函数之外的new运算符。在构造函数内部创建的对象被传回变量var。虽然看起来有了new运算符了,比工厂方式有了一些进步,但是这种实现方式也是会出现重复创建方法的问题。因此也不推荐使用这种方式来定义类。

推荐整理分享javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)(js中的类是什么),希望有所帮助,仅作参考,欢迎阅读内容。

javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)(js中的类是什么)

文章相关热门搜索词:js类class的作用,javascript class类,js类class的作用,javascript 类,js中的类是什么,js中的类和对象,javascript 类,javascript中类的继承,内容如对您有帮助,希望把文章链接给更多的朋友!

JS继承 笔记 JS继承JavaScript中没有类的概念,与类相关的继承的概念更是无从谈起,但是我们可以通过特殊的语法来模拟面向对象语言中的继承。在JS中模拟继承有

Javascript 面向对象编程(一) 封装 学习Javascript,最难的地方是什么?我觉得,Object(对象)最难。因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握。下面就是我

Javascript面向对象编程(二) 构造函数的继承 今天要介绍的是,如何生成一个"继承"多个对象的实例。比如,现在有一个"动物"对象的构造函数,functionAnimal(){this.species="动物";}还有一个"猫"对象的构

标签: js中的类是什么

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

上一篇:javascript复制对象使用说明(js复制div)

下一篇:JS继承 笔记(js继承的概念)

  • 以房抵债的房子交房产税吗
  • 公司注销前存货低价标准
  • 退税现金流量表做哪里
  • 公司减免社保到几月份
  • 定期定额户申报表怎么填
  • 受雇于两家公司个税怎么汇算清缴
  • 装修收入如何填报增值税表
  • 小微企业要缴纳印花税吗
  • 印花税自查补缴要先申报吗
  • 分公司企业所得税汇总缴纳还是单独缴纳
  • 非盈利组织是两套账吗?
  • 银行汇票存款和银行存款的区别
  • 合同印花税用不用计提
  • 个体工商户销售自己使用过的物品
  • 高新企业季度企业所得税预征税率
  • 公司增值税进项税不够还有什么办法处理
  • 汇算清缴前发票未到
  • 公司法人要交什么税
  • 金税盘最高限额怎么修改
  • 员工年终福利发什么
  • 发票冲红还需要作废吗
  • 一次性收取跨年租金房产税怎么交
  • 对方转出没收到怎么办
  • 年终奖金计税方式区别
  • 现金流量表的编制依据
  • 待摊费用当月增加
  • 如何win10家庭版升级专业版
  • mac只能读不能写
  • 交上年企业所得税怎么做会计分录
  • 森林植被恢复费标准
  • 电脑总是死机
  • outlook的数据文件
  • 收到业绩补偿会扣税吗
  • 安徽4岁男孩户口已解决
  • 发票多盖了一个发票章咋办
  • Obsidian:实现日记记录【设计并使用模板】
  • 微信小程序的视频怎么下载
  • php 跨域
  • 年度预算的意义
  • 公司注销开户行需要注销吗
  • 因质量原因退货和召回的产品,均应按照规定
  • 当月勾选认证可以在下月抵扣吗
  • 一般纳税人进项大于销项账务处理
  • mysql详细教程
  • 织梦怎么改网站主页
  • 自查补税怎么做账
  • 收取水电费计入什么科目
  • 哪些福利不需要交个税
  • 购买增值税发票属于什么科目?
  • 小微企业所得税税率多少
  • 关联方交易的税收问题
  • 预收账款的核算处理
  • 流动资产周转天数高说明什么
  • 法人向公司借款如何做账
  • 政府扶持资金的优缺点
  • 购买税盘全额抵扣会计分录
  • 营业执照增加经营范围需要法人去吗
  • win10免费安装吗
  • solaris newfs
  • acs_log是什么文件
  • MS DTC 事务管理器无法启动的解决方案
  • freebsd怎么安装软件
  • windows怎么定位
  • ghost到一半报错
  • Win7 vpn连接不上怎么办?Win7系统vpn连接不上问题的解决方法
  • 简洁桌面怎么设置
  • android:Background线程池和UiThread线程池
  • cocos2d游戏引擎
  • linux 搜索文件
  • shell sed 空格
  • 批处理文本文件如何建立
  • jquery是基于java的吗
  • easyui导出excel表格
  • activity启动流程图解
  • 批处理的扩展名
  • python方法有哪些
  • android图片适配方法
  • 如何查看税务登记信息
  • 盐城企退人员养老金调整新标准
  • 增值税税控开票软件怎么下载
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设