理解JavaScript的prototype屬性
更新時(shí)間:2012年02月11日 23:30:16 作者:
JavaScript可以說(shuō)是最讓人初學(xué)者難以理解的單一屬性。我看了一些資料后,開(kāi)始明白其實(shí)這些困難很大程度來(lái)自prototype這個(gè)名字本身的二義性
其實(shí),關(guān)于prototype只要幾句話就可以總結(jié):
任何原型都是對(duì)象,只有對(duì)象有原型
只有Function有prototype屬性,它是這個(gè)Function作為構(gòu)造器時(shí)生成對(duì)象所繼承的原型。Function的原型和它的prototype屬性無(wú)關(guān)
對(duì)象的原型可以通過(guò)非標(biāo)準(zhǔn)的屬性 __proto__ 或ECMAScript5的方法 Object.getPrototypeOf() 訪問(wèn)。
1其實(shí)是錯(cuò)的,Object這個(gè)原型鏈盡頭的對(duì)象它沒(méi)有原型??墒菫榱烁?jiǎn)單表述。在看原型鏈后你就會(huì)明白.toString()這類(lèi)沒(méi)有定義過(guò)的方法是怎樣來(lái)的。
上面說(shuō)的二義性,是文字理解上的,語(yǔ)法本身沒(méi)有歧義。prototype是原型的意思,可是一個(gè)對(duì)象的原型不是由prototype去訪問(wèn)。
Function有prototype屬性,可是和自己的原型沒(méi)有關(guān)系。理解這點(diǎn)后,再去看關(guān)于原型鏈、繼承的文章就容易理解多了。
下面是些例子,可以加深認(rèn)識(shí):
// 任何對(duì)象都有原型
obj = {};
console.log( obj.__proto__ );
console.log( Object.getPrototypeOf(obj) );
console.log( obj.__proto__ === Object.getPrototypeOf(obj) );
//對(duì)象并沒(méi)有語(yǔ)法意義的prototype屬性
alert(obj.prototype) //undefined
//prototype作為一個(gè)屬性,僅存在于Function中,代表以這個(gè)Function創(chuàng)建的新實(shí)例集成的原型,和Function本身的原型無(wú)關(guān)
var F = function(name){
this.name = name;
}
obj = {a:3,
get b (){
return this.a;
}
};
F.prototype = obj;
newObj = new F('new name');
newObj.name; //作為構(gòu)造器,name是newObj的自身屬性
newObj.a; //3
//它繼承了obj??梢酝ㄟ^(guò)這樣證實(shí):
Object.getPrototypeOf( newObj ) === obj; // true
newObj.__proto__ === obj; //true
任何原型都是對(duì)象,只有對(duì)象有原型
只有Function有prototype屬性,它是這個(gè)Function作為構(gòu)造器時(shí)生成對(duì)象所繼承的原型。Function的原型和它的prototype屬性無(wú)關(guān)
對(duì)象的原型可以通過(guò)非標(biāo)準(zhǔn)的屬性 __proto__ 或ECMAScript5的方法 Object.getPrototypeOf() 訪問(wèn)。
1其實(shí)是錯(cuò)的,Object這個(gè)原型鏈盡頭的對(duì)象它沒(méi)有原型??墒菫榱烁?jiǎn)單表述。在看原型鏈后你就會(huì)明白.toString()這類(lèi)沒(méi)有定義過(guò)的方法是怎樣來(lái)的。
上面說(shuō)的二義性,是文字理解上的,語(yǔ)法本身沒(méi)有歧義。prototype是原型的意思,可是一個(gè)對(duì)象的原型不是由prototype去訪問(wèn)。
Function有prototype屬性,可是和自己的原型沒(méi)有關(guān)系。理解這點(diǎn)后,再去看關(guān)于原型鏈、繼承的文章就容易理解多了。
下面是些例子,可以加深認(rèn)識(shí):
復(fù)制代碼 代碼如下:
// 任何對(duì)象都有原型
obj = {};
console.log( obj.__proto__ );
console.log( Object.getPrototypeOf(obj) );
console.log( obj.__proto__ === Object.getPrototypeOf(obj) );
//對(duì)象并沒(méi)有語(yǔ)法意義的prototype屬性
alert(obj.prototype) //undefined
//prototype作為一個(gè)屬性,僅存在于Function中,代表以這個(gè)Function創(chuàng)建的新實(shí)例集成的原型,和Function本身的原型無(wú)關(guān)
var F = function(name){
this.name = name;
}
obj = {a:3,
get b (){
return this.a;
}
};
F.prototype = obj;
newObj = new F('new name');
newObj.name; //作為構(gòu)造器,name是newObj的自身屬性
newObj.a; //3
//它繼承了obj??梢酝ㄟ^(guò)這樣證實(shí):
Object.getPrototypeOf( newObj ) === obj; // true
newObj.__proto__ === obj; //true
您可能感興趣的文章:
- 談?wù)刯s中的prototype及prototype屬性解釋和常用方法
- js的Prototype屬性解釋及常用方法
- JavaScript中prototype為對(duì)象添加屬性的誤區(qū)介紹
- JavaScript中幾個(gè)重要的屬性(this、constructor、prototype)介紹
- JavaScript prototype屬性深入介紹
- javascript中的prototype屬性使用說(shuō)明(函數(shù)功能擴(kuò)展)
- javascript中的prototype屬性實(shí)例分析說(shuō)明
- JavaScript為對(duì)象原型prototype添加屬性的兩種方式
- 詳解Javascript中prototype屬性(推薦)
相關(guān)文章
js仿百度登錄頁(yè)實(shí)現(xiàn)拖動(dòng)窗口效果
這篇文章主要為大家詳細(xì)介紹了js仿百度登錄頁(yè)實(shí)現(xiàn)拖動(dòng)窗口效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03js驗(yàn)證真實(shí)姓名與身份證號(hào),手機(jī)號(hào)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇js驗(yàn)證真實(shí)姓名與身份證號(hào),手機(jī)號(hào)的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07JS實(shí)現(xiàn)仿餓了么在瀏覽器標(biāo)簽頁(yè)失去焦點(diǎn)時(shí)網(wǎng)頁(yè)Title改變
這篇文章主要介紹了JS實(shí)現(xiàn)仿餓了么在瀏覽器標(biāo)簽頁(yè)失去焦點(diǎn)時(shí)網(wǎng)頁(yè)Title改變,需要的朋友可以參考下2017-06-06input禁止鍵盤(pán)及中文輸入,但可以點(diǎn)擊
這篇文章主要介紹了<input>禁止鍵盤(pán)及中文輸入,但可以點(diǎn)擊。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02JS實(shí)現(xiàn)的模仿QQ頭像資料卡顯示與隱藏效果
這篇文章主要介紹了JS實(shí)現(xiàn)的模仿QQ頭像資料卡顯示與隱藏效果,涉及javascript鼠標(biāo)事件響應(yīng)及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)技巧,需要的朋友可以參考下2017-04-04javascript正則表達(dá)式之search()用法實(shí)例
這篇文章主要介紹了javascript正則表達(dá)式之search()用法,實(shí)例分析了search()的使用技巧,需要的朋友可以參考下2015-01-01JS中setTimeout的巧妙用法前端函數(shù)節(jié)流
這篇文章主要介紹了JS中setTimeout的巧妙用法前端函數(shù)節(jié)流 的相關(guān)資料,需要的朋友可以參考下2016-03-03