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)鍵字來看,實(shí)例既是父類的實(shí)例,又是子類的實(shí)例,看起來似乎是最純粹的繼承。
    缺點(diǎn):子類區(qū)別于父類的屬性和方法,必須在Sub.prototype = new Base();這樣的語句之后分別執(zhí)行,無法被包裝到Sub這個(gè)構(gòu)造器里面去。例如:Sub.prototype.name = “sub”;無法實(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),對象不是父類的實(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):是父類的對象,并且使用new構(gòu)造對象和不使用new構(gòu)造對象,都可以獲得相同的效果。
    缺點(diǎn):生成的對象實(shí)質(zhì)僅僅是父類的實(shí)例,并非子類的對象;不支持多繼承。
    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):效率較低;無法獲取父類不可枚舉的方法。
    這幾種形式各有特點(diǎn),僅就我提供的代碼而言,滿足下面的表格:
    2012-1-10:補(bǔ)充,如果我們不需要類繼承,只需要對象繼承,對于支持 ECMAScript 5 的瀏覽器來說,還可以用Object.create方法來實(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";