分享更有价值
被信任是一种快乐

js中的Object.create方法怎么使用

文章页正文上

这篇文章主要介绍“js中的Object.create方法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“js中的Object.create方法怎么使用”文章能帮助大家解决问题。ECMAScript 5 新增了 Object.create() 方法将原型式继承的概念规范化用法

varobj=Object.create({name:'johan',age:23})//obj继承了属性name和age
varobj2=Object.create(null)//obj2不继承任何属性和方法
varobj3=Object.create(Object.prototype)//与{}和newObject()一个意思
varobj4=Object.create({},{
property1:{
value:true,
writable:true
}
})//第二个参数与Object.defineProperties()一致
图解Object.create实现
functioncreate(proto){
functionF(){}
F.prototype=proto
returnnewF()
}

第一步: function F(){}

第一步: function F(){}
即创建一个函数,因为约定首字母大写,视为构造函数,创建函数 F 时,F 构造函数与和它的原型对象就有了这一层的关系:

F.prototype===F.prototype;//假设你把F.prototype当作一个值
F.prototype.constructor===F;

第二步:F.prototype = proto即将 F.prototype 赋值为传入的 proto,如此就打破了F.prototype = F.prototype 以及 F.prototype.constructor = F ,它们的关系为第三步:return new F()第三步的解读有点费解,因为这里涉及到 new 的操作,在 new 改变了对象 中我们说过,new 会创建一个对象,并将这个对象的隐式原型(__proto__) 指向构造函数的原型对象,并初始化构造函数,如果值则返回值。我们也会在后续的原型中介绍,new 是隐式原型继承,Object.create 是显式原型继承在这里,我们按实现 new 的方式来解读 return new F()。new F 后的实例的 __proto__ 指向的是 F.prototype,而这个值已经在第二步时指给了传来的 proto,所以就有了new F().__proto__ = proto或许你还是不太清楚第三步,我们结合例子,就一目了然了

varobj=Object.create({name:'johan'})

第三步的图解就成了这样:

第三步的图解就成了这样:
这样就成了, obj 继承自{name: johan} 这个对象免费云主机、域名,至于F.prototype = {name: ‘johan’},在调用完 Object.create 之后,也因为没人使用 F 函数而被引擎当作垃圾回收了,遂成了obj.__proto__ = {name: ‘johan’}如此「原型式继承」就被传承下来了其原理就是如此,简单来说,就是创建空(构造)函数,关联它的原型(实现继承)

Object.create(null)

在阅读源码时,常会看到 Object.create(null) ,用此初始化一个新对象,至于为什么用这个方法而不用 new Object 或者 {},是因为无论 new 还是字面量,都是继承自 Object 构造函数,而使用Object.create(null) ,能得到一个没有任何继承痕迹的对象

varobj=Object.create(null)

在阅读源码时,常会看到 Object.create(null) ,用此初始化一个新对象,至于为什么用这个方法而不用 new Object 或者 {},是因为无论 new 还是字面量,都是继承自 Object 构造函数,而使用Object.create(null) ,能得到一个没有任何继承痕迹的对象
关于“js中的Object.create方法怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注云技术行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: 怎么使用javascript和jquery分别实现用户登录验证

这篇文章主要介绍“怎么使用javascript和jquery分别实现用户登录验证”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用javascript和jquery分别实现用户登录验证”文章能帮助大家解决免费云主机…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册