*以下全文用[[Prototype]]
代表对象真正的原型链
prototype
与__proto__
的区别
__proto__
是真正的原型链,也就是[[Prototype]]
,使用原型链时,查找对象的属性是通过__proto__
来查找,而不是prototype
-
varFoo=function(){}; Foo.__proto__.a ='b'; Foo.prototype.a ='a'; alert(Foo.a);//b
-
prototype
只是用于构建用new
关键字创建的对象,将构造器函数的prototype
的引用指向于构建的对象的__proto__
-
varFoo=function(){}; var test =newFoo(); alert(test.__proto__ ===Foo.prototype);//true
-
- 构造器函数的
prototype
与__proto__
是不相同的,其protoype
会被构建的对象的[[Prototype]]
引用,其[[Prototype]]
是Function
对象的[[Prototype]]
,Function
对象的prototype
与__proto__
是相同的-
varFoo=function(){}; alert(Foo.prototype ===Foo.__proto__);//false alert(Function.__proto__ ===Foo.__proto__);//true alert(Function.__proto__ ===Function.prototype);//true
constructor也就是构造器函数的引用,一个构造器函数的constructor
是什么prototype
的constructor
也就等于这个构造器函数本身,一个构造器函数的__proto__
的constructor
,也就是Function
的consturctor
就等于Function
本身-
varFoo=function(){}; var test =newFoo(); alert(Foo.constructor ===Function);//true alert(Foo.prototype.constructor === test.constructor);//true alert(Foo=== test.constructor);//true alert(Foo.constructor ===Foo.prototype.constructor);// false
一个对象的构造过程
-
Foo |_ protoype |_ consturctor === Foo |_ __proto__ === Object.prototype |_ constuctor === Object |_ __proto__ === null |_ __proto__ |_ __proto__ === Function.protoype |_ constuctor === Function |_ __proto__ === Object.protoype |_ consturctor === Object |_ __proto__ === null
test |_ __proto__ === Foo.protoype |_ constructor === Foo |_ __proto__ === Object.protoype |_ constuctor === Object |_ __proto__ === null
protoype
属性,Object.__proto__ === Function.__proto__
,Object.__proto__.contructor === Object
-