对象.原型链,函数.原型对象

栏目: JavaScript · 发布时间: 5年前

内容简介:对象.原型链、函数.原型对象之间的关系只要想明白这四点,就通透了。哪四点呢?1.

对象.原型链、函数.原型对象之间的关系只要想明白这四点,就通透了。

哪四点呢?

1. 对象中,有个__proto__属性

原型链的实现就是通过该属性;

2. 函数中,有个prototype属性

这个属性是个对象, 叫做原型对象

3. 对象 是由 对应的构造函数new 出来的,

所以, 对象的__proto__会指向构造函数的 prototype属性

4. 函数也是个对象 ,是由 Function函数new 出来的,

所以,函数的__proto__会指向Fuction的 prototype属性

另外, Function函数也构造了自己,Fucntion.__proto__ === Function.prototype;

说的多,不如看个图直观,看图的关键是把握:

对象被构造函数new出来后, 对象的_proto__ 会指向 构造函数的prototype属性

对象.原型链,函数.原型对象

用上图,我们就可以解释很多神奇的现象了,

1. 原型链,也就是__proto__最后都指向了Object.prototype,而该原型对象的__proto__ === null;

2. Function instanceof Object === Object instanceof Fucntion === true;

instanceof通俗的说法是,判断左边对象是不是右边函数new出来的实例;这种说话就会让上述表达式很矛盾;但是,换个说法,instanceof本质上是用来,判断 右边函数的原型对象 是否在 左边对象的原型链 上;

由于Fuction函数和Object函数都是由Function函数new出来的,导致Function.__proto__和Object.__proto__指到一块去了,而Function.prototype和Object.prototype正好都在链上,所以就造就了上述的神奇表达式。

参考:

juejin.im/post/58f9d0…

juejin.im/post/583586…


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

影响力

影响力

[美] 罗伯特·西奥迪尼 / 陈叙 / 中国人民大学出版社 / 2006-5 / 45.00元

政治家运用影响力来赢得选举,商人运用影响力来兜售商品,推销员运用影响力诱惑你乖乖地把金钱捧上。即使你的朋友和家人,不知不觉之间,也会把影响力用到你的身上。但到底是为什么,当一个要求用不同的方式提出来时,你的反应就会从负面抵抗变成积极合作呢? 在这本书中,心理学家罗伯特·B·西奥迪尼博士为我们解释了为什么有些人极具说服力,而我们总是容易上当受骗。隐藏在冲动地顺从他人行为背后的6大心理秘笈,正是......一起来看看 《影响力》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码