位置: 编程技术 - 正文

javascript创建对象的几种模式介绍(javascript创建对象)

编辑:rootadmin

推荐整理分享javascript创建对象的几种模式介绍(javascript创建对象),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js创建对象的方法有哪些,javascript创建对象的几种方法,JavaScript创建对象方法,JavaScript创建对象的关键字,JavaScript创建对象数组,javascript创建对象,JavaScript创建对象方法,javascript创建对象的三种方法,内容如对您有帮助,希望把文章链接给更多的朋友!

在js中有几种模式可以创建对象,通过对象操作所包含的属性与方法。

一般来说,构造函数名称的第一个字母为大写字母,非构造函数名称的第一个字母为小写字母,当然,构造函数与一般函数唯一的区别只是调用的方式不同而已,所以任何函数只要通过new来调用,那它就可以作为构造函数,若不通过new来调用,则与一般函数一样。

谈谈我对这几种模式的理解:

工厂模式:创建一个一般函数,在函数里创建一个Object对象,为这个对象增添属性与方法,同时赋予其值,最后返回对象。无法识别对象类型。

构造函数模式:创建构造函数,使用this来赋值,每当创建一个实例时,方法都被创建一次,而每个方法都执行相同的命令,这就多余了。这个缺点可以通过将方法放到全局环境中,但是,这样就没有封装性了。不过可以通过原型模式解决。

原型模式:每个函数都有一个prototype属性,该属性是一个指针,指向一个对象,该对象包含其函数创建的所有实例共享的属性与方法。

原型对象,构造函数以及实例之间的关系如下图:

图解:1:构造函数以及由构造函数创建的实例,它们的prototype属性都指向构造函数的原型对象。

2:构造函数的原型对象具有constructor属性,该属性指向构造函数。

3:构造函数的原型对象所包含的所有属性与方法可以被由构造函数所创建的所有实例共享。

javascript创建对象的几种模式介绍(javascript创建对象)

使用对象字面量重写原型对象后,constructor则指向object构造函数,若需要其指向另一构造函数,则需修改原型对象的constructor属性的值,比如:constructor:Person,这样Person的原型对象即使被重写,原型对象的constructor仍指向Person构造函数。

当先创建实例时:若是直接添加属性或方法,实例可以访问。

若是重写原型对象,则构造函数的prototype指向新的原型对象,而之前创建的实例的prototype仍指向最初的原型对象,所以实例访问不到新的原型对象的新属性或和新方法。

原型对象包含的是共享的属性与方法,那么每个实例都拥有这些信息,这样实例之间就没有什么不同了,而且还不可以传参数,这不是我们所想要的。每个实例之间有共同的信息,又有不同的信息,所以我们可以组合使用构造函数模式与原型模式。

构造函数模式与原型模式的组合使用:

态原型模式:将独立的构造函数与其原型对象结合在一起,在构造函数里初始化原型,为其添加方法。

若该方法不存在,则将其添加到原型对象上,只在初始化原型时才执行,而且只执行一次。

寄生构造函数模式:与工厂模式类似,区别为:寄生构造函数模式为构造函数,通过new来创建实例。

稳妥构造函数模式:没有公共的属性,其方法不引用this的对象。创建实例时不使用new。只能通过方法访问属性(即传入的数据)。

以上这篇javascript创建对象的几种模式介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

JavaScript中的原型继承基础学习教程 大多数编程语言中,都有类和对象,一个类可以继承其他类。在JavaScript中,继承是基于原型的(prototype-based),这意味着JavaScript中没有类,取而代之的

JavaScript中的prototype原型学习指南 原型是什么Function类型有一个属性prototype,直接翻译过来就是原型。这个属性就是一个指针,指向一个对象,这个对象包含一些属性和方法,这些属性和

详解JavaScript中的自定义事件编写 我们可以自定义事件来实现更灵活的开发,事件用好了可以是一件很强大的工具,基于事件的开发有很多优势(后面介绍)。与自定义事件的函数有Event

标签: javascript创建对象

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

上一篇:JavaScript中各种引用类型的常用操作方法小结(js中的)

下一篇:JavaScript中的原型继承基础学习教程(js中的原型是什么)

  • 综合保税区内企业
  • 小企业汇算清缴所得税会计分录
  • 资产负债表其他应收款怎么填列
  • 普票丢失了能作废重开吗
  • 中介行业风险
  • 本年本期累计
  • 本年利润是负数的会计分录
  • 现金比率计算公式含义
  • 施工企业确认收入的方法有哪两种
  • 如何处理没有录音的人
  • 清算汇缴报表填写模板
  • 子公司注销后人员怎么安置
  • 机会成本怎么计量
  • 日记账的填制
  • 如何填写企业所得税
  • 如何设置老板键
  • 冲销上月暂估入账的原材料会计分录
  • 网速怎么限制10mb以内
  • 跨年退税怎么处理
  • hppusg.exe是什么进程
  • 安全生产专用设备目录
  • 公司以知识产权出资纳税筹划
  • 进项税额不得抵扣的情况有哪些
  • 企业借款费用处理不当会产生什么样的后果呢?
  • 基金会债券收入吗
  • php请求https
  • php限制接口调用次数
  • ant desgin-vue
  • php function函数的用法
  • 审稿意见范例
  • this.emit('input')
  • wordpress小工具开发
  • 应交税费的期末余额在借方表示什么
  • 广告费支出税前扣除标准30
  • 公司给员工的福利房可以买卖吗
  • opengl环境光参数
  • js逻辑表达式
  • php clone函数
  • 建筑业委托加工合同范本
  • 所得税汇算清缴账务处理
  • 消防设备要多少钱
  • 小规模纳税人企业所得税2023
  • mysql数据库压力测试工具
  • 不用交社保的几种情况
  • 水利建设基金申报表哪里
  • 购买税控系统的增值税怎么处理
  • 应缴国库款和应缴财政专户款有什么区别
  • 买公司宿舍有保障吗
  • 行政单位的财务报表包括哪些
  • 工会筹备金该按什么计算
  • 何为生产型企业
  • 固定资产可以一次性入费用的标准
  • 合作社开具免税发票流程
  • 房地产会计相关内容
  • 非营利医疗机构由谁批准
  • windows7内部版本7601激活密钥
  • xp更改dns
  • bios怎么设置efi引导
  • centos重新安装命令
  • linux 消耗内存命令
  • 用javascript
  • jquery实现表单验证
  • 欢迎使用来电提醒业务是什么意思
  • linux中的命令及含义
  • css全局样式基础代码
  • 项目总结之触摸问题分析
  • json详细教程
  • html手机号验证
  • 如何修改android studio的下载路径
  • pull order
  • shell命令su
  • nodejs body-parser 解析post数据实例
  • js实现继承的几种方式详述(推荐)
  • 手游炫酷
  • 四个落实是哪四个落实
  • 四川国税发票查验真伪
  • 婚育证明可以开假的吗
  • 同比减少怎么计算出来
  • 上海市浦东新区人民医院
  • 消费税的纳税人是买方还是卖方
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设