js原型链
首先要知道js几乎皆为对象,但是对象又由函数所创建。在原生链构造函数既是函数也是个对象。__proto__和prototype都指向原型对象,区别就是一个是对象指向原型对象,一个是对象的构造函数指向原型对象。原型对象的本质就是一个另一个构造函数的实例。
在js中最大的原型就是Object.prototype。
js会在一开始 function Object(),function Function。就是自带Object和Function这两个构造器.。
最主要注意的其实是这个Function,它其实是导致我们对原型链难以理解的主要原因,它比较特殊,它既为一个构造函数同时也是一个自己构造出来的一个实例对象,因此他的__proto__与prototype都指向Function.prototype。这是因为机制上Function是创建函数的构造函数Function(),例如一个函数的创建可以为:
var Foo=new Function("a","b","return a+b");
var f=Foo(1,2);
console.log(f);
但是Function()无法创建构造函数,最多只能创建工厂函数,但这么做它(Foo)的本质其实只是对匿名函数的引用,起到一个标识符的作用,因此编译器对他的识别也只是个匿名函数。
对于function标识符来说就可以创建一个能让编译器识别的函数,这是我目前认为这两者的区别。但function和new Function()创造函数应该都算是Function()这个构造函数。
//构造器的建立
function Foo(name,age){
this.name=name;
this.age=age;
}
var p1=new Foo("","");
因为Object()是由function创建出来的,因此Object是function的一个对象。所以Object()的__proto__指向Function.prototype。然后后面自己定义的对象其实跟Object对象在原型链上没什么区别只不过名字不同罢了。
总结
主要要理解的事情就是函数是个对象,而对象又是由函数所创造;
也就是Object().__proto__的是由function构造出来的一个实例对象。
而function.proto原型又是一个对象由Object()所创造出来的一个实例对象。总体而言,原型对象是由构造函数对象所生成(这里的对象不指Object对象,例如:原型对象继承XX1.prototype=new XX2();这个原型对象刚刚创立的时候的确是Object对象的实例,但因为此代码他成了XX2构造函数对象的实例),而构造函数对象都是Function()构造函数的实例对象。
然后就是一张网上的图助于理解