javaScript面向?qū)ο蟆^承

繼承的概念

繼承:子類可以訪問(wèn)父類的所有屬性和方法黎棠,并且可以對(duì)這些屬性和方法進(jìn)行擴(kuò)展

繼承的幾種方式

  • 原型鏈繼承

    利用原型讓一個(gè)對(duì)象繼承另一個(gè)對(duì)象的屬性和方法,轩性,即把一個(gè)對(duì)象的原型作為另一個(gè)對(duì)象的實(shí)例倘潜,這樣就可以繼承另一個(gè)對(duì)象的屬性和方法

    優(yōu)點(diǎn):

    1. 簡(jiǎn)單易于實(shí)現(xiàn),父類的新增的實(shí)例與屬性子類都能訪問(wèn)

    缺點(diǎn):

    1. 子類更改從父類繼承過(guò)來(lái)的引用類型的屬性淆珊,由于原型屬性中的引用類型屬性會(huì)被所有實(shí)例共享,因此會(huì)影響其他實(shí)例
    2. 創(chuàng)建子類實(shí)例時(shí)奸汇,沒(méi)有辦法在不影響其他實(shí)例的情況下向超類型的構(gòu)造函數(shù)中傳參施符、
    3. 可以在子類中增加實(shí)例屬性,如果要新增加原型屬性和方法需要在new 父類構(gòu)造函數(shù)的后面
    4. 無(wú)法實(shí)現(xiàn)多繼承擂找、
    5. 創(chuàng)建子類實(shí)例時(shí)戳吝,不能向父類構(gòu)造函數(shù)中傳參數(shù)
    function People (name){
        this.name = name
        this.say = function(){
            console.log('hello')
        }
    }
    
    // 01.原型鏈繼承
    
    function Child1 (age) {
        this.age = age
    }
    Child1.prototype = new People('xiaoming')
    let xiaoming = new Child1(18)
    console.log(xiaoming.name,xiaoming.age) // xiaoming 18
    
  • 借用構(gòu)造函數(shù)

    在函數(shù)內(nèi)部通過(guò)call或apply去繼承超類型屬性或方法

    優(yōu)點(diǎn):

    1. 解決了子類構(gòu)造函數(shù)向父類構(gòu)造函數(shù)中傳遞參數(shù)
    2. 可以實(shí)現(xiàn)多繼承(call或者apply多個(gè)父類)

    缺點(diǎn):

    1. 方法都在構(gòu)造函數(shù)中定義,無(wú)法復(fù)用
    2. 不能繼承原型屬性/方法贯涎,只能繼承父類的實(shí)例屬性和方法
    function People (name){
        this.name = name
        this.say = function(){
            console.log('hello')
        }
    }
    
    function Child2 (name,age) {
        People.call(this,name)
        this.age = age
    }
    
    let xiaoming = new Child2('xiaoming',18)
    console.log(xiaoming.name,xiaoming.age) // xiaoming 18
    
  • 組合繼承

    使用原型鏈實(shí)現(xiàn)原型屬性和方法的繼承听哭,使用借用構(gòu)造函數(shù)來(lái)實(shí)現(xiàn)對(duì)實(shí)例屬性的繼承

    優(yōu)點(diǎn):

    1. 函數(shù)可以復(fù)用
    2. 不存在引用屬性問(wèn)題
    3. 可以繼承屬性和方法,并且可以繼承原型的屬性和方法

    缺點(diǎn): 需要調(diào)用兩次父類

    function People (name){
        this.name = name
        this.say = function(){
            console.log('hello')
        }
    }
    
    function Child3(name,age){
        this.age = age 
        People.call(this,name)// 第一次調(diào)用
    }
    Child3.prototype = new People('xiaoming')//第二次調(diào)用
    People.prototype.constructor = People
    let xiaoming = new Child3('xiaoming',18)
    console.log(xiaoming.name,xiaoming.age) // xiaoming 18
    
  • 原型式繼承

    把一個(gè)對(duì)象作為另一個(gè)對(duì)象的基礎(chǔ),通過(guò)一個(gè)中介構(gòu)造函數(shù)去創(chuàng)建一個(gè)實(shí)例陆盘。

    // 方式1
    function object(o) {
      var F = function(){}
      F.prototype = o
      return new F()
    }
    var person2 = object(obj)
    // 方式2
    var person1 = Object.create(obj, {
    name: {
      value: 'person1'
    }})
    
  • 寄生式繼承

    創(chuàng)建一個(gè)用來(lái)封裝繼承過(guò)程的函數(shù)普筹,在該函數(shù)的內(nèi)部通過(guò)某種方式來(lái)增強(qiáng)對(duì)象,然后返回這個(gè)對(duì)象隘马。

    • 可以將最開(kāi)始的對(duì)象擴(kuò)展后,返回被繼承

    • 通原型鏈繼承一樣,此時(shí)無(wú)法獲取到構(gòu)造函數(shù)屬性

    • 寄生繼承直接指向父類的prototype,所以不會(huì)重復(fù)調(diào)用父類的情況

    let obj = {
        name: '小明',
        age: 18,
        like: ['吃飯', '睡覺(jué)']
    }
    
    function createFn(ob) {
        let o = Object.create(ob)
        o.sayHi = function () {
            console.log('hi')
        }
        return o
    }
    
    let child4 = createFn(obj)
    console.log(child4.name,child4.age)// 小明 18
    
  • 寄生組合繼承

    通過(guò)借用構(gòu)造函數(shù)方式繼承屬性太防,通過(guò)原型鏈混成方式繼承方法

    通過(guò)寄生的方式來(lái)修復(fù)組合式繼承的不足,完美的實(shí)現(xiàn)繼承

    People.prototype.eat = function () {
        console.log('吃飯')
    }
    //子類
    function  Man(name,age) {
        People.call(this,name)
        this.age = age
    }
    
    //繼承父類的方法
    function  createFn(father,child) {
        let o = Object.create(father.prototype)
        console.log(o)
        o.constructor = child
        child.prototype = o
    }
    createFn(People, Man)
    let person1 = new Man('xiaoming',18)
    console.log(person1.name,person1.age)// xiaoming 18
    
  • ES6繼承

    class People {
        constructor(name ,age){
            this.name = name
            this.age = age
        }
        like () {
            console.log('吃飯','睡覺(jué)')
        }
    }
    
    class Man extends People {
        constructor(name,age){
            //繼承父類屬性
            super(name,age)
        }
        like () {
            super.like()
        }
    }
    
    let people = new Man('xiaoming',18)
    console.log(people.name,people.age)//xiaoming 18
    people.like()
    
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末酸员,一起剝皮案震驚了整個(gè)濱河市蜒车,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌幔嗦,老刑警劉巖醇王,帶你破解...
    沈念sama閱讀 216,324評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異崭添,居然都是意外死亡寓娩,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門呼渣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)棘伴,“玉大人,你說(shuō)我怎么就攤上這事屁置『缚洌” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,328評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵蓝角,是天一觀的道長(zhǎng)阱穗。 經(jīng)常有香客問(wèn)我,道長(zhǎng)使鹅,這世上最難降的妖魔是什么揪阶? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,147評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮患朱,結(jié)果婚禮上鲁僚,老公的妹妹穿的比我還像新娘。我一直安慰自己裁厅,他們只是感情好冰沙,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著执虹,像睡著了一般拓挥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上袋励,一...
    開(kāi)封第一講書(shū)人閱讀 51,115評(píng)論 1 296
  • 那天侥啤,我揣著相機(jī)與錄音当叭,去河邊找鬼。 笑死愿棋,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的均牢。 我是一名探鬼主播糠雨,決...
    沈念sama閱讀 40,025評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼徘跪!你這毒婦竟也來(lái)了甘邀?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,867評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤垮庐,失蹤者是張志新(化名)和其女友劉穎松邪,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體哨查,經(jīng)...
    沈念sama閱讀 45,307評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡逗抑,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寒亥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邮府。...
    茶點(diǎn)故事閱讀 39,688評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖溉奕,靈堂內(nèi)的尸體忽然破棺而出褂傀,到底是詐尸還是另有隱情,我是刑警寧澤加勤,帶...
    沈念sama閱讀 35,409評(píng)論 5 343
  • 正文 年R本政府宣布仙辟,位于F島的核電站,受9級(jí)特大地震影響鳄梅,放射性物質(zhì)發(fā)生泄漏叠国。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評(píng)論 3 325
  • 文/蒙蒙 一戴尸、第九天 我趴在偏房一處隱蔽的房頂上張望煎饼。 院中可真熱鬧,春花似錦校赤、人聲如沸吆玖。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,657評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)沾乘。三九已至,卻和暖如春浑测,著一層夾襖步出監(jiān)牢的瞬間翅阵,已是汗流浹背歪玲。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,811評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留掷匠,地道東北人滥崩。 一個(gè)月前我還...
    沈念sama閱讀 47,685評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像讹语,于是被迫代替她去往敵國(guó)和親钙皮。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評(píng)論 2 353