javascript中的prototype屬性實(shí)例分析說明
更新時(shí)間:2010年08月09日 23:39:45 作者:
一說到prototype很多人可能第一個(gè)想到的是著名的prototype.js框架,當(dāng)然我們今天說的不是它,而是Javascript中的prototype屬性,一般都被翻譯為“原型”。這是一個(gè)比較特殊的屬性,Javascript中的繼承一般都依賴這屬性實(shí)現(xiàn)。
在Javascript中,一切都是對(duì)象,字符串是對(duì)象,數(shù)組是對(duì)象,變量是對(duì)象,函數(shù)也是對(duì)象,所以才會(huì)允許['a','b','c'].push('d');這樣的操作存在。類本身也是一個(gè)對(duì)象,也可以定義屬性和方法:
function Test(){};
Test.str = 'str';
Test.fun = function(){return 'fun';};
var r1 = Test.str; // str
var r2 = Test.fun(); // fun
var inst = new Test();
var r3 = inst.str; // undefined
var r4 = inst.fun(); // undefinedprototype就是一個(gè)作用于類的屬性。默認(rèn)情況下,所有Javascript類都會(huì)有一個(gè)prototype屬性,但是類實(shí)例沒有。
function Test(){};
var p1 = typeof(String.prototype); // object
var p2 = typeof(Test.prototype); // object
var p3 = typeof(new Test().prototype); // undefined
var p4 = typeof(Object.prototype); // object
var p5 = typeof(new Object().prototype); // undefined取值與賦值
在Javascript中,當(dāng)我們?nèi)∫粋€(gè)對(duì)象中并不存在的屬性或是方法時(shí),它會(huì)試圖查看該對(duì)象所對(duì)應(yīng)的類中的prototype屬性中是否包含該屬性或是方法,而prototype也是一個(gè)Javascript對(duì)象,若是其中也沒有,該prototype又會(huì)訪問它對(duì)應(yīng)的類的prototype,如此一級(jí)級(jí)地向上訪問,直到找到需要的屬性或方法,或是prototype屬性為null。
function Test(){};
Test.test = 'str';
function pt1()
{ this.test1 = 'pt1'; };
function pt2()
{ this.test2 = 'pt2'; };
pt2.prototype.test3 = 'test3';
pt2.prototype.test1 = 'test4';
pt1.prototype = new pt2();
Test.prototype = new pt1();
var inst = new Test();
var p1 = inst.test; // undefined
var p2 = inst.test1; // pt1 而不是 test4
var p3 = inst.test2; // pt2
var p4 = inst.test3; // test3相對(duì)于取值,賦值就簡(jiǎn)單得多了。
它并不會(huì)一層層向上查找prototype中的屬性值,而直接對(duì)當(dāng)前的實(shí)例進(jìn)行賦值,沒有則創(chuàng)建。
內(nèi)置類的增強(qiáng)
在Javascript中并不能直接修改內(nèi)置類的prototype。但是可以通過修改prototype的屬性達(dá)到修改內(nèi)置類行為的目的。
Array.prototype = {push:function(){alert('test1');}}; // 不起作用
Array.prototype.push = function(){alert('test2');}; // 可以
var test = new Array('a','b','c');
test.push('d'); // test2一次可以插入多個(gè)元素的Array.push函數(shù):
Array.prototype.pushs = function()
{
var pos = this.length;
for(var i=0; i<arguments.length; i++)
{
this[++pos] = arguments[i];
}
return this.length;
}
var test = new Array('a','b','c');
test.pushs('d','e');
值得注意的是,為內(nèi)置類的prototype添加的函數(shù),在使用for語(yǔ)句輸出屬性時(shí),也會(huì)被顯示:
var str;
for(var i in test)
{
str += (' ' + i); // '0 1 2 3 4 5 pushs' pushs自定義函數(shù)。
}
但是可以通過hasOwnProperty()進(jìn)行判斷:
var str;
for(var i in test)
{
if(test.hasOwnProperty(i)) // 過濾掉pushs函數(shù)。
{ str += (' ' + i); }
}
一點(diǎn)點(diǎn)注意事項(xiàng)
前面說過,prototype是類的一個(gè)屬性。更改prototype中的屬性值,有可能會(huì)帶來意想不到的災(zāi)難!
function Test(){}
Test.prototype.num = 3;
var inst1 = new Test();
var inst2 = new Test();
Test.prototype.num = 4; // 所有指向Test.prototype.num的值。
var p1 = inst1.num; // 4
var p2 = inst2.num; // 4
inst1.num = 5; // 賦值,會(huì)為inst對(duì)象創(chuàng)建一個(gè)num屬性。
Test.prototype.num = 6; // 所有指向Test.prototype.num的值。
var p3 = inst1.num; // 5 這里返回的是剛創(chuàng)建的inst1.num的值,而不是Test.prototype.num的值。
var p4 = inst2.num; // 6
delete Test.prototype.num;
var p5 = inst1.num; // 5 inst1.num依然存在。
var p6 = inst2.num; // undefined Test.prototype.num 被刪除了。
復(fù)制代碼 代碼如下:
function Test(){};
Test.str = 'str';
Test.fun = function(){return 'fun';};
var r1 = Test.str; // str
var r2 = Test.fun(); // fun
var inst = new Test();
var r3 = inst.str; // undefined
var r4 = inst.fun(); // undefinedprototype就是一個(gè)作用于類的屬性。默認(rèn)情況下,所有Javascript類都會(huì)有一個(gè)prototype屬性,但是類實(shí)例沒有。
function Test(){};
var p1 = typeof(String.prototype); // object
var p2 = typeof(Test.prototype); // object
var p3 = typeof(new Test().prototype); // undefined
var p4 = typeof(Object.prototype); // object
var p5 = typeof(new Object().prototype); // undefined取值與賦值
在Javascript中,當(dāng)我們?nèi)∫粋€(gè)對(duì)象中并不存在的屬性或是方法時(shí),它會(huì)試圖查看該對(duì)象所對(duì)應(yīng)的類中的prototype屬性中是否包含該屬性或是方法,而prototype也是一個(gè)Javascript對(duì)象,若是其中也沒有,該prototype又會(huì)訪問它對(duì)應(yīng)的類的prototype,如此一級(jí)級(jí)地向上訪問,直到找到需要的屬性或方法,或是prototype屬性為null。
復(fù)制代碼 代碼如下:
function Test(){};
Test.test = 'str';
function pt1()
{ this.test1 = 'pt1'; };
function pt2()
{ this.test2 = 'pt2'; };
pt2.prototype.test3 = 'test3';
pt2.prototype.test1 = 'test4';
pt1.prototype = new pt2();
Test.prototype = new pt1();
var inst = new Test();
var p1 = inst.test; // undefined
var p2 = inst.test1; // pt1 而不是 test4
var p3 = inst.test2; // pt2
var p4 = inst.test3; // test3相對(duì)于取值,賦值就簡(jiǎn)單得多了。
它并不會(huì)一層層向上查找prototype中的屬性值,而直接對(duì)當(dāng)前的實(shí)例進(jìn)行賦值,沒有則創(chuàng)建。
內(nèi)置類的增強(qiáng)
在Javascript中并不能直接修改內(nèi)置類的prototype。但是可以通過修改prototype的屬性達(dá)到修改內(nèi)置類行為的目的。
復(fù)制代碼 代碼如下:
Array.prototype = {push:function(){alert('test1');}}; // 不起作用
Array.prototype.push = function(){alert('test2');}; // 可以
var test = new Array('a','b','c');
test.push('d'); // test2一次可以插入多個(gè)元素的Array.push函數(shù):
Array.prototype.pushs = function()
{
var pos = this.length;
for(var i=0; i<arguments.length; i++)
{
this[++pos] = arguments[i];
}
return this.length;
}
var test = new Array('a','b','c');
test.pushs('d','e');
值得注意的是,為內(nèi)置類的prototype添加的函數(shù),在使用for語(yǔ)句輸出屬性時(shí),也會(huì)被顯示:
復(fù)制代碼 代碼如下:
var str;
for(var i in test)
{
str += (' ' + i); // '0 1 2 3 4 5 pushs' pushs自定義函數(shù)。
}
但是可以通過hasOwnProperty()進(jìn)行判斷:
復(fù)制代碼 代碼如下:
var str;
for(var i in test)
{
if(test.hasOwnProperty(i)) // 過濾掉pushs函數(shù)。
{ str += (' ' + i); }
}
一點(diǎn)點(diǎn)注意事項(xiàng)
前面說過,prototype是類的一個(gè)屬性。更改prototype中的屬性值,有可能會(huì)帶來意想不到的災(zāi)難!
復(fù)制代碼 代碼如下:
function Test(){}
Test.prototype.num = 3;
var inst1 = new Test();
var inst2 = new Test();
Test.prototype.num = 4; // 所有指向Test.prototype.num的值。
var p1 = inst1.num; // 4
var p2 = inst2.num; // 4
inst1.num = 5; // 賦值,會(huì)為inst對(duì)象創(chuàng)建一個(gè)num屬性。
Test.prototype.num = 6; // 所有指向Test.prototype.num的值。
var p3 = inst1.num; // 5 這里返回的是剛創(chuàng)建的inst1.num的值,而不是Test.prototype.num的值。
var p4 = inst2.num; // 6
delete Test.prototype.num;
var p5 = inst1.num; // 5 inst1.num依然存在。
var p6 = inst2.num; // undefined Test.prototype.num 被刪除了。
您可能感興趣的文章:
- 談?wù)刯s中的prototype及prototype屬性解釋和常用方法
- js的Prototype屬性解釋及常用方法
- JavaScript中prototype為對(duì)象添加屬性的誤區(qū)介紹
- JavaScript中幾個(gè)重要的屬性(this、constructor、prototype)介紹
- JavaScript prototype屬性深入介紹
- 理解JavaScript的prototype屬性
- javascript中的prototype屬性使用說明(函數(shù)功能擴(kuò)展)
- JavaScript為對(duì)象原型prototype添加屬性的兩種方式
- 詳解Javascript中prototype屬性(推薦)
相關(guān)文章
關(guān)于RxJS Subject的學(xué)習(xí)筆記
這篇文章主要介紹了關(guān)于RxJS Subject的學(xué)習(xí)筆記,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12完美解決mui框架off-canvas側(cè)滑超出部分隱藏?zé)o法滾動(dòng)的問題
下面小編就為大家分享一篇完美解決mui框架off-canvas側(cè)滑超出部分隱藏?zé)o法滾動(dòng)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01擁有一個(gè)屬于自己的javascript表單驗(yàn)證插件
這篇文章主要幫助大家擁有一個(gè)屬于自己的javascript表單驗(yàn)證插件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03js創(chuàng)建數(shù)據(jù)共享接口——簡(jiǎn)化框架之間相互傳值
很多框架存在父子關(guān)系,操作起來十分麻煩,很多同學(xué)經(jīng)常出現(xiàn)這樣悲催的代碼2011-10-10js實(shí)現(xiàn)從右往左勻速顯示圖片(無縫輪播)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)從右往左勻速顯示圖片,無縫輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06js實(shí)現(xiàn)帶有介紹的Select列表菜單實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)帶有介紹的Select列表菜單,涉及javascript頁(yè)面元素的動(dòng)態(tài)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08js實(shí)現(xiàn)數(shù)字遞增特效【仿支付寶我的財(cái)富】
本篇文章主要介紹了js實(shí)現(xiàn)仿支付寶我的財(cái)富里的數(shù)字遞增特效,具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-05-05JavaScript設(shè)計(jì)模式之性能優(yōu)化模式享元模式
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之性能優(yōu)化模式享元模式,享元設(shè)計(jì)模式是用于性能優(yōu)化的模式,這種設(shè)計(jì)模式的核心在于可以共享技術(shù)并支持對(duì)大量細(xì)分過后的對(duì)象進(jìn)行調(diào)整,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下2022-06-06