|
在原型鏈繼承方面,JavaScript與Java、c#等語言類似,僅允許單父類繼承。prototype繼承的基本方式如下:
復(fù)制代碼 代碼如下:
function Parent(){}
function Child(){}
Child.prototype = new Parent();
通過對象Child的prototype屬性指向父對象Parent的實例,使Child對象實例能通過原型鏈訪問到父對象構(gòu)造所定義的屬性、方法等。
構(gòu)造通過原型鏈鏈接了父級對象,是否就意味著完成了對象的繼承了呢?答案是否定的。如:
復(fù)制代碼 代碼如下:
function Parent(){}
function Child(){}
Child.prototype = new Parent();
var child = new Child();
alert(child.constructor);//function Parent(){}
alert(child instanceof Child);//true
盡管child依然可以作為Child的實例使用,但此時已經(jīng)丟失了實例child原有的對象構(gòu)造信息。彌補該缺陷的方法如下:
復(fù)制代碼 代碼如下:
function Parent(){}
function Child(){}
Child.prototype = new Parent();
Child.prototype.constructor = Child;
var child = new Child();
alert(child.constructor);//function Parent(){}
alert(child instanceof Child);//true
如上代碼片段“Child.prototype.constructor = Child”所示,通過顯示地指定對象構(gòu)造Child的原型,強制所有的Child對象實例的構(gòu)造都為Child。
二、使用apply、call方法
由于JavaScript內(nèi)置的Function對象的apply、call方法改變對象構(gòu)造中“this”的上下文環(huán)境,使特定的對象實例具有對象構(gòu)造中所定義的屬性、方法。
使用apply、call繼承,在實際開發(fā)中操作HTML頁面上的DOM對象時尤為常用。如:
復(fù)制代碼 代碼如下:
<div id="extend">apply,call繼承</div>
<script language="Javascript">
function ext()
{
this.onclick=function(){alert(this.innerHTML)}
}
ext.apply(document.getElementById("extend"));
ext.call(document.getElementById("extend"));
</script>
通過apply或call定義的ext方法,使ext方法內(nèi)部的this上下文表示為DOM對象“<div id="extend">apply,call繼承</div>”。
值得注意的是,當使用apply、call時,會直接執(zhí)行對象構(gòu)造所定義的代碼段,如:
復(fù)制代碼 代碼如下:
<script language="Javascript">
function testExec()
{
alert("執(zhí)行!");
}
testExec.call(null);//彈出execute對話框
testExec.apply(null);//彈出execute對話框
</script>
三、對象實例間的繼承
JavaScript對象的多態(tài)性,允許實例動態(tài)地添加屬性、方法。該特性造就了JavaScript中的另一種繼承手法――對象實例間的繼承。如:
復(fù)制代碼 代碼如下:
var Person = {name:"nathena",age:"26"};
var nathena = {sex:"male"};
(function inlineExtends(so,po)
{
for (var i in po)
{
if (so[i])//如果so也具有這個成員
continue;
so[i] = po[i];
}
})(nathena,Person);
alert(nathena.name);//返回nathana
如以上代碼所示,在對象的實例間繼承中,父對象Persong定義了“人”所具有的共同屬性name、age,子對象nathena定義了自己的私有屬性“sex”。函數(shù)inlineExtends的功能是,為子對象nathena復(fù)制父對象Person中定義的“人”所具有的共同屬性。
其中特別需要注意的語句是“if (so[i])”,此句確保了子對象原有的成員不被父對象中同名的成員所覆蓋,而違背面向?qū)ο笾懈缸訉ο笾g繼承的原則――子對象可以覆蓋、重載父對象的屬性或方法,父對象僅能對子對象隱藏自己的屬性或方法。
JavaScript技術(shù):實現(xiàn)JavaScript中繼承的三種方式,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。