企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
>Function与Object原型的关系是很多面试题中必考的内容,其本质还是原型链的继承。 <br /> - 首先Object和Function都是构造函数,而所有的构造函数的都是Function的实例对象. 因此 - Object是Function的实例对象 - Function.prototype是Object的实例对象 - 实例对象的原型(我们以proto来表示)会指向其构造函数的prototype属性, 因此 - Object.proto ===Function.prototype - 解释:因为Object是Function实例对象,所以Objct的原型就是Function的原型属性 - Function.proto === Function.prototype - 解释:Function也是Function的实例方法,所以Function的原型指向Function的原型属性 - Function.prototype.proto === Object.prototype - 解释:Function的原型属性是继承自Function的原型属性,Object的原型属性也是继承自Function的原型属性,所以Function的原型属性的原型等于Object的原型属性 - 当我们访问一个属性值的时候, 它会沿着原型链向上查找, 直到找到或者到Object.prototype.proto(为null)截止. ```javascript var foo = {}; var F = function(){}; Object.prototype.a = 'value a'; Function.prototype.b = 'value b'; console.log(foo.a) // value a console.log(foo.b) // undefined console.log(F.a) // value a console.log(F.b) // value b ```