var Base = function()
{
this.level = 1;
this.name = "base";
this.toString = func " /> 久久久久久久久久成人,久久久久久久综合,欧美色图自拍

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

JavaScript實現(xiàn)繼承的4種方法總結(jié)

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

1、原型鏈繼承:

復(fù)制代碼 代碼如下:
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)點:從instanceof關(guān)鍵字來看,實例既是父類的實例,又是子類的實例,看起來似乎是最純粹的繼承。

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

2、構(gòu)造繼承:

復(fù)制代碼 代碼如下:
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)點:可以實現(xiàn)多重繼承,可以把子類特有的屬性設(shè)置放在構(gòu)造器內(nèi)部。

缺點:使用instanceof發(fā)現(xiàn),對象不是父類的實例。

3、實例繼承:

復(fù)制代碼 代碼如下:
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)點:是父類的對象,并且使用new構(gòu)造對象和不使用new構(gòu)造對象,都可以獲得相同的效果。

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

4、拷貝繼承:

復(fù)制代碼 代碼如下:
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)點:支持多繼承。

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

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

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

復(fù)制代碼 代碼如下:
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技術(shù)JavaScript實現(xiàn)繼承的4種方法總結(jié),轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 寡妇高潮一级毛片情欲小说| 人流后吃什么| 古装发型| 失魂家族| 祈今朝电视剧| 贝加尔湖畔指弹吉他谱| 杨玉环秘史| 最火图片| 维京人电影| 白雪公主在线| 韩国电影两个小姨子| 大雄的日本诞生| 快乐到家| 唐朝诡事录在线观看全集免费观看| 帕米尔的春天简谱| 张天喜| ,xx| 高达uce| 在线播放啄木乌丝袜秘书| 钱串子图片| 伪装者 豆瓣| 来生缘吉他谱c调| 次强音| himym| 江西省高中生综合素质自我评价| 原创视频| 知否知否应是绿肥红瘦观看| 徐若晗个人简历| 我们的日子演员表| 康熙微服记四部免费观看在线| 104房间| 吴薇| 黑手党电影| 无锡电视台| 唐瑜苏沐月是哪部短剧| 刘浩存个人资料简介图片| 维拉·法梅加| 童女之舞| 绿门背后| 一级特黄新婚之夜| 5xx.com|