javascript原型与原型链
============================================================================
1. prototype
每个函数都有一个prototype属性,被称为显示原型
============================================================================
2._ proto _
1、每个实例对象都会有_ proto _属性,其被称为隐式原型
2、每一个实例对象的隐式原型_ proto _属性指向自身构造函数的显式原型prototype
============================================================================
3. constructor
每个prototype原型都有一个constructor属性,指向它关联的构造函数。
============================================================================
4. 原型链
获取对象属性时,如果对象本身没有这个属性,那就会去他的原型__proto__上去找,如果还查不到,就去找原型的原型,一直找到最顶层(Object.prototype)为止。Object.prototype对象也有__proto__属性值为null。
这里需要注意的是Object是属于原型链的顶层,所有构造函数的的prototype都指向 Object. prototype
============================================================================
function Fun ( ) {
}
var fn= new Fun ( )
console. log ( fn. __proto__=== Fun. prototype)
console. log ( Fun. __proto__=== Function. prototype)
console. log ( Function. __proto__=== Function. prototype)
console. log ( Function. prototype. __proto__=== Object. prototype)
console. log ( Fun. prototype. __proto__=== Object. prototype)
console. log ( Object. __proto__=== Function. prototype)
console. log ( Object. prototype. __proto__=== null )
var obj= { }
console. log ( obj. __proto__=== Object. prototype)
console. log ( obj. __proto__. __proto__=== null )
console. log ( obj. __proto__. constructor=== Object)
console. log ( obj. __proto__. constructor. __proto__=== Function. prototype)
console. log ( obj. __proto__. constructor. __proto__. __proto__=== Object. prototype)
console. log ( obj. __proto__. constructor. __proto__. __proto__. __proto__=== null )
console. log ( obj. __proto__. constructor. __proto__. __proto__. constructor. __proto__=== Function. prototype)
============================================================================