前言:用了这么久js,对于它的原型链一直有种模糊的不确切感,很不爽,隧解析之。javascript
本文主要解决的问题有如下三个:java
(1)constructor 和 prototype 以及实例之间啥关系?函数
(2)prototype是啥,__proto__又是啥,他们之间啥关系?spa
(3)若是改变一个 constructor 的 prototype,他的实例会发生什么改变?prototype
ok,下面一个一个解决。3d
(1)constructor 和 prototype 以及实例对象三者之间啥关系?指针
举例:对象
如上,当咱们建立一个函数,系统就会为这个函数自动分配一个prototype指针,指向它的原型对象。而且能够发现,这个原型对象包含两个部分(constructor 和 __proto__)其中constructor指向函数自身。(这里造成了一个小闭环)blog
当咱们将该函数做为模版建立实例(new方法)的时候,咱们发现建立出的实例是一个与构造函数同名的object,这个object是独立的,他只包含了一个__proto__指针(实例没有prototype,强行访问则会输出undefined),这个指针指向上面提到的构造函数的prototype原型对象。ip
这时候咱们发现三者造成了一个大"闭环"。之因此加上引号,由于构造函数和实例之间没法直接访问,须要经过__proto__指针间接读取。
这个"大闭环"画出来就是下面这个样子啦:
到此第一个问题已经解决。
(2)prototype是啥,__proto__又是啥,他们之间啥关系?
在上一个问题中,咱们用到了实例对象的__proto__指针,实际上在JavaScript中大部分类型的值都拥有__proto__属性,例如:
固然object和function对象也有:
不过也有不存在__proto___属性的类型,好比:
等等。
然而。只有function对象才有prototype属性,其余任何类型的值都没有。即便是使用new方法从function构造出的实例对象也没有prototype属性。
(object类型的值的prototype输出undefined)
(咱们改变了test的prototype的值,将其连接到一个函数名为test的函数,接着,函数类型的值的prototype输出了一个原型对象)
so,do you understand?
(3)若是改变一个 constructor 的 prototype,他的实例会发生什么改变?
咱们来作一个尝试:
咱们能够发现,改变了prototype以后建立的实例指向了新的prototype对象,而以前的依然指向老的prototype对象。
下面是个应用这个方法拓展实例的小例子:
var shape = function () { }; var p = { a: function () { console.log('aaa'); } }; shape.prototype = p; var circle = new shape(); circle.a(); //输出'aaa'
好啦,到这里就讲完啦~~撒花哈哈哈哈~~~
本文内容原创,转载请告知~