javascript
JS 原型链 prototypt 和隐式原型 _proto_
prototype(原型) :? 對象的一個屬性,此屬性使您有能力向?qū)ο筇砑訉傩院头椒?#xff0c;當(dāng)訪問對象不存在屬性是會自動到 prototype 中找
_proto_(隱式原型): 此對象構(gòu)造函數(shù)(類)的原型(prototype)
constructor: 原型對象的一個屬性,指回原構(gòu)造函數(shù)
注意
基于同一個類(構(gòu)造函數(shù))生產(chǎn)的對象共享一個 prototype , 任何一個對象修改會影響其他對象,例如下面代碼中,xiaohei 修改了Dog 類prototype中的 foods 屬性,xiaobai 的也隨之改變
function Dog(name,color){this.name = namethis.color = color}Dog.prototype={foods : ['bones','meal','fish'],say : function(){console.log('汪汪汪,my name is '+this.name)},eat : function(){console.log('my foods is '+this.foods.join(','))}}var xiaohei = new Dog('小黑','black');var xiaobai = new Dog('小白','white');xiaohei.__proto__.foods.push('shit');xiaobai.eat();輸出 : my foods is bones,meal,fish,shit使用new關(guān)鍵字調(diào)用函數(shù)(new?ClassA(…))的具體步驟:
1. 創(chuàng)建空對象;
var obj = {};
2. 設(shè)置新對象的constructor屬性為構(gòu)造函數(shù)的名稱,設(shè)置新對象的__proto__屬性指向構(gòu)造函數(shù)的prototype對象;
obj.__proto__ = ClassA.prototype;
3. 使用新對象調(diào)用函數(shù),函數(shù)中的this被指向新實例對象:
ClassA.call(obj); //{}.構(gòu)造函數(shù)(); ? ? ? ? ?
4. 將初始化完畢的新對象地址,保存到等號左邊的變量中
?
?
總結(jié):
- 對象有屬性__proto__,指向該對象的構(gòu)造函數(shù)的原型對象。
- 方法除了有屬性__proto__,還有屬性prototype,prototype指向該方法的原型對象。
轉(zhuǎn)載于:https://www.cnblogs.com/xiaoliwang/p/9035200.html
總結(jié)
以上是生活随笔為你收集整理的JS 原型链 prototypt 和隐式原型 _proto_的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: javascript 实现快排 ,三向切
- 下一篇: Spring Cloud + Sprin