JavaScript實(shí)現(xiàn)繼承的4種方法總結(jié)
JavaScript雖沒有給出繼承的關(guān)鍵字,但是我們依然能夠拿出一些好辦法實(shí)現(xiàn)。
1、原型鏈繼承:
var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = function(){
return "base";
};
};
Base.CONSTANT = "constant";
var Sub = function()
{
};
Sub.prototype = new Base();
Sub.prototype.name = "sub";
優(yōu)點(diǎn):從instanceof關(guān)鍵字來(lái)看,實(shí)例既是父類的實(shí)例,又是子類的實(shí)例,看起來(lái)似乎是最純粹的繼承。
缺點(diǎn):子類區(qū)別于父類的屬性和方法,必須在Sub.prototype = new Base();這樣的語(yǔ)句之后分別執(zhí)行,無(wú)法被包裝到Sub這個(gè)構(gòu)造器里面去。例如:Sub.prototype.name = “sub”;無(wú)法實(shí)現(xiàn)多重繼承。
2、構(gòu)造繼承:
var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = function(){
return "base";
};
};
Base.CONSTANT = "constant";
var Sub = function()
{
Base.call(this);
this.name = "sub";
};
優(yōu)點(diǎn):可以實(shí)現(xiàn)多重繼承,可以把子類特有的屬性設(shè)置放在構(gòu)造器內(nèi)部。
缺點(diǎn):使用instanceof發(fā)現(xiàn),對(duì)象不是父類的實(shí)例。
3、實(shí)例繼承:
var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = function(){
return "base";
};
};
Base.CONSTANT = "constant";
var Sub = function()
{
var instance = new Base();
instance.name = "sub";
return instance;
};
優(yōu)點(diǎn):是父類的對(duì)象,并且使用new構(gòu)造對(duì)象和不使用new構(gòu)造對(duì)象,都可以獲得相同的效果。
缺點(diǎn):生成的對(duì)象實(shí)質(zhì)僅僅是父類的實(shí)例,并非子類的對(duì)象;不支持多繼承。
4、拷貝繼承:
var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = function(){
return "base";
};
};
Base.CONSTANT = "constant";
var Sub = function()
{
var base = new Base();
for(var i in base)
Sub.prototype[i] = base[i];
Sub.prototype["name"] = "sub";
};
優(yōu)點(diǎn):支持多繼承。
缺點(diǎn):效率較低;無(wú)法獲取父類不可枚舉的方法。
這幾種形式各有特點(diǎn),僅就我提供的代碼而言,滿足下面的表格:

2012-1-10:補(bǔ)充,如果我們不需要類繼承,只需要對(duì)象繼承,對(duì)于支持 ECMAScript 5 的瀏覽器來(lái)說(shuō),還可以用Object.create方法來(lái)實(shí)現(xiàn):
var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = function(){
return "base";
};
};
Base.CONSTANT = "constant";
var sub = Object.create(new Base());
sub.name = "sub";
相關(guān)文章
bootstrap-wysiwyg結(jié)合ajax實(shí)現(xiàn)圖片上傳實(shí)時(shí)刷新功能
這篇文章主要為大家詳細(xì)介紹了bootstrap-wysiwyg結(jié)合ajax實(shí)現(xiàn)圖片上傳實(shí)時(shí)刷新功能,感興趣的小伙伴們可以參考一下2016-05-05
js簡(jiǎn)單實(shí)現(xiàn)表單中點(diǎn)擊按鈕動(dòng)態(tài)增加輸入框數(shù)量的方法
這篇文章主要介紹了js簡(jiǎn)單實(shí)現(xiàn)表單中點(diǎn)擊按鈕動(dòng)態(tài)增加輸入框數(shù)量的方法,涉及javascript鼠標(biāo)點(diǎn)擊事件及insertAdjacentHTML方法的相關(guān)使用技巧,需要的朋友可以參考下2015-08-08
JavaScript設(shè)計(jì)模式之建造者模式實(shí)例教程
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之建造者模式,結(jié)合實(shí)例形式分析了設(shè)計(jì)模式中建造者模式的概念、功能及JavaScript實(shí)現(xiàn)與使用建造者模式的相關(guān)操作技巧,需要的朋友可以參考下2018-07-07
前端微信H5公眾號(hào)實(shí)現(xiàn)授權(quán)登錄的方法總結(jié)
這篇文章主要介紹了如何在微信公眾號(hào)中實(shí)現(xiàn)網(wǎng)頁(yè)授權(quán)功能,包括創(chuàng)建微信服務(wù)公眾號(hào)、配置重定向地址、調(diào)試和開發(fā)使用等步驟,文中通過(guò)圖文及代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-01-01

