博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浅谈Object.create
阅读量:6300 次
发布时间:2019-06-22

本文共 756 字,大约阅读时间需要 2 分钟。

在网上发现了Object.create的用法,感觉很是奇怪,所以学习记录下

1 var o = Object.create(null);2 console.log(o); // {}3 o.name = 'jian';4 var o2 = Object.create(o);5 console.log(o2); // {}6 console.log(o2.name); // 'jian',

百度了一下原理:

1 Object.create =  function (o) {2     var F = function () {};3     F.prototype = o;4     return new F();5 };

再看一段代码:

1 var Base = function () {
2 }3 Base.prototype.a = 3;4 var o1 = new Base();5 var o2 = Object.create(Base);6 console.log(o1.a);//37 console.log(o2.a);//undefined 8 o2.__proto__.prototype.a//3

为什么呢:因为o2的原型链中并没有a这个属性但是根据之前代码Object.create的原理来看return new F();

那么假设这个o2=new F();因此可以推出o2.__proto__ = F.prototype=Base(此原理请参见之前文章面向对上中的图二),而Base.prototype.a = 3;

因此o2.__proto__.prototype.a=3

转载于:https://www.cnblogs.com/ones/p/8453984.html

你可能感兴趣的文章
再学 GDI+[43]: 文本输出 - 获取已安装的字体列表
查看>>
nginx反向代理
查看>>
ARM想将芯片装进人类大脑 降低能耗是一大挑战
查看>>
Oracle数据库的备份方法
查看>>
Selenium 自动登录考勤系统
查看>>
关于如何以编程的方式执行TestNG
查看>>
智能照明造福千家万户 家居智能不再是梦
查看>>
物联网如何跳出“看起来很美”?
查看>>
浅谈MySQL 数据库性能优化
查看>>
《UNIX/Linux 系统管理技术手册(第四版)》——1.10 其他的权威文档
查看>>
用CSS画一个带阴影的三角形
查看>>
solr-4.10.4部署到tomcat6
查看>>
切片键(Shard Keys)
查看>>
淘宝API-类目
查看>>
virtualbox 笔记
查看>>
检验手机号码
查看>>
重叠(Overlapped)IO模型
查看>>
Git使用教程
查看>>
使用shell脚本自动监控后台进程,并能自动重启
查看>>
Flex&Bison手册
查看>>