js_原型链的问题
2021-03-12 10:28
标签:fun code struct font ref nta contain str function 所有的构造函数都是构造函数Function的实例(允许该构造函数直接通过constructor属性访问构造函数Function) 所有的原型对象都可以近似看成构造函数Object的实例(不允许该原型对象直接通过constructor属性访问构造函数Object) 示例: 现有构造函数Foo,其实例对象foo,其原型对象Foo.prototype。还有Function构造函数,Object构造函数 所有的构造函数都是构造函数Function的实例(允许该构造函数直接通过constructor属性访问构造函数Function) 所有的原型对象都可以近似看成构造函数Object的实例(不允许该原型对象直接通过constructor属性访问构造函数Object) js_原型链的问题 标签:fun code struct font ref nta contain str function 原文地址:https://www.cnblogs.com/Syinho/p/12827651.html
判断构造函数、实例对象、原型对象之间的关系
var l = console.log;
function Foo() {}
var foo = new Foo();
//Foo构造函数
l(foo.constructor == Foo); //true
l(Foo.prototype.constructor == Foo); //true
l(foo.__proto__ == Foo.prototype); //true
//Function构造函数
l(new Function().constructor == Function); //true
l(Function.prototype.constructor == Function); //true
l(new Function().__proto__ == Function.prototype); //true
//Object构造函数
l(new Object().constructor == Object); //true
l(Object.prototype.constructor == Object); //true
l(new Object().__proto__ == Object.prototype); //true
Object构造函数与Function构造函数之间的联系
//所有的构造函数都是构造函数Function的实例(允许该构造函数直接通过constructor属性访问构造函数Function)
l(Object.constructor == Function); //true
l(Object.__proto__==Function.prototype);//true
//所有的原型对象都可以近似看成构造函数Object的实例(不允许该原型对象直接通过constructor属性访问构造函数Object)
l(Function.prototype.__proto__ == Object.prototype); //true
l(Function.prototype.constructor == Object);//false