标签:__proto__和prototype object和function javascript原型
(typeof Object.prototype) === object;//true Object.prototype.__proto__=== null;//true Object.prototype.prototype === undefied;//true
function Person() { } var obj = {}; alert(obj.__proto__ === Object.prototype);//true alert(Person.__proto__ === Function.prototype);//truejavascript中对象是由Object创建的,函数是由Function创建的。
Object.__proto__ === Function.prototype;
//函数对象 function Person() { } // 普通对象 var obj = {}; obj.__proto__ === Object.prototype;//true obj.prototype === undefined;//true Person.__proto__ === Function.prototype;//true Person.prototype !== undefined;//true我们知道javascript正是通过prototype实现继承的。如果objA、objB都是由cFunction创建的,那么根据结论2,objA.__proto__ === objB.__proto__ === cFunction.prototype,也就是说objA和objB对象都继承了cFunction的prototype。原型链是基于__proto__形成的,继承是通过prototype实现的。
(typeof Function.prototype) === function;//true Function.prototype.prototype === undefined;//true
(typeof Function.__proto__) === function;//true Function.__proto__=== Function.prototype;//trueFunction这个函数对象,由其自身通过Function函数构造的。
(typeof Function.prototype.__proto__) === object;//true Function.prototype.__proto__=== Object.prototype;//true
理清javascript中prototype、__proto__、Object、Function的关系,更好地理解原型继承
标签:__proto__和prototype object和function javascript原型
原文地址:http://blog.csdn.net/aitangyong/article/details/44837655