var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = func " /> 依人青青青在线观看,91精品婷婷国产综合久久8,成片免费观看视频大全

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript實現繼承的4種方法總結

JavaScript雖沒有給出繼承的關鍵字,但是我們依然能夠拿出一些好辦法實現。

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";

優點:從instanceof關鍵字來看,實例既是父類的實例,又是子類的實例,看起來似乎是最純粹的繼承。

缺點:子類區別于父類的屬性和方法,必須在Sub.prototype = new Base();這樣的語句之后分別執行,無法被包裝到Sub這個構造器里面去。例如:Sub.prototype.name = “sub”;無法實現多重繼承。

2、構造繼承:

復制代碼 代碼如下:
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"; 
};

優點:可以實現多重繼承,可以把子類特有的屬性設置放在構造器內部。

缺點:使用instanceof發現,對象不是父類的實例。

3、實例繼承:

復制代碼 代碼如下:
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; 
};

優點:是父類的對象,并且使用new構造對象和不使用new構造對象,都可以獲得相同的效果。

缺點:生成的對象實質僅僅是父類的實例,并非子類的對象;不支持多繼承。

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"; 
};

優點:支持多繼承。

缺點:效率較低;無法獲取父類不可枚舉的方法。

這幾種形式各有特點,僅就我提供的代碼而言,滿足下面的表格:

2012-1-10:補充,如果我們不需要類繼承,只需要對象繼承,對于支持 ECMAScript 5 的瀏覽器來說,還可以用Object.create方法來實現:

復制代碼 代碼如下:
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";

JavaScript技術JavaScript實現繼承的4種方法總結,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产 亚洲 日韩 欧美 在线观看 | 中俄两军在日本海等上空战略巡航 | 国产成人无码免费精品果冻传媒 | 亚洲国产成人精品无码区APP | 久久精品人人做人人爽97 | 嫩草影院地址一地址二 | 超碰国产视频免费播放 | 精品国产在线亚洲欧美 | 日本无码人妻精品一区二区视频 | 亚洲精品视频在线观看视频 | 国产AV国片精品无套内谢无码 | A级毛片高清免费网站不卡 a级毛片高清免费视频 | 国产麻豆福利AV在线观看 | 亚洲 欧美 国产 综合五月天 | 欧美亚洲高清国产 | 精品午夜中文字幕熟女人妻在线 | 最近日本免费观看MV免费 | 国产99视频在线观看 | 玩弄朋友娇妻呻吟交换电影 | 高清观看ZSHH96的视频素材 | 午夜国产在线观看 | 扒开美女下面粉嫩粉嫩冒白浆 | 亚洲黄色免费观看 | 亚洲精品AV中文字幕在线 | 亚洲精品国产在线观看 | 熟妇少妇任你躁在线无码 | 精品国产福利在线视频 | 欧美fxxx| 午夜影视不用充钱的免费 | 中字幕视频在线永久在线 | 又亲又揉摸下面视频免费看 | 日韩av国产av欧美天堂社区 | 思思99热久久精品在线6 | 白人大战34厘米黑人BD | 精品国产成人系列 | 日本乱子人伦在线视频 | 精品国产麻豆免费人成网站 | 久久欧洲AV无码精品色午夜麻豆 | 欧美国产一区二区三区激情无套 | 国产亚洲欧洲日韩在线三区 | 大桥未久与黑人中出视频 |