Javascript組合繼承方法代碼實(shí)例解析

組合繼承
組合繼承,指將原型鏈和借用構(gòu)造函數(shù)的技術(shù)組合到一塊,從而發(fā)揮二者之長(zhǎng)的一種繼承模式。其背后思路使用用原型鏈實(shí)現(xiàn)對(duì)原型屬性和方法的繼承,而通過(guò)構(gòu)造函數(shù)來(lái)實(shí)現(xiàn)對(duì)實(shí)例屬性的繼承。這樣,即通過(guò)在原型上定義方法實(shí)現(xiàn)了函數(shù)復(fù)用,又能夠保證每個(gè)實(shí)例都有它自己的屬性。
下面來(lái)看一個(gè)例子
function SuperType(name) {
this.name = name;
this.color = ['red', 'blue', 'green'];
};
//
SuperType.prototype.sayName = function() {
console.log(this.name);
};
//
function SubType(name, age) {
//繼承屬性
SuperType.call(this, name); // 第二次調(diào)用SuperType
//
this.age = age;
};
//繼承方法
SubType.prototype = new SuperType(); // 第一次調(diào)用SuperType
console.log(SubType.prototype.constructor); //輸出SuperType函數(shù)的源碼,即此時(shí)SubType.prototype.constructor指向SuperType函數(shù)
SubType.prototype.constructor = SubType; //將SubType.prototype.constructor指針指回SubType函數(shù)
SubType.prototype.sayAge = function() {
console.log(this.age);
};
//
var instance1 = new SubType('Jake', 20)
instance1.color.push('black');
console.log(instance1.color); //'red,blue,green,black'
instance1.sayName(); //'Jake'
instance1.sayAge(); //20
//
var instance2 = new SubType('Greg', 21);
console.log(instance2.color); //'red,blue,green'
instance2.sayName(); //'Greg';
instance2.sayAge(); //21
觀察輸出結(jié)果,便可以發(fā)現(xiàn):兩個(gè)SubType實(shí)例(instance1和instance2)既分別有自己的屬性,又可以使用相同的方法。
優(yōu)點(diǎn)
組合繼承避免了原型鏈和借用構(gòu)造函數(shù)的缺陷,融合了它們的優(yōu)點(diǎn),所以是JS中最常用的繼承模式。而且,instanceof和isPrototypeOf()也能夠用于識(shí)別基于組合繼承創(chuàng)建的對(duì)象。
缺點(diǎn)
調(diào)用兩次SuperType構(gòu)造函數(shù)
在SubType.prototype上創(chuàng)建了不必要的屬性
寄生組合繼承
function SuperType (name) {
this.name = name
this.colors = ['red', 'blue', 'yellow']
}
SuperType.prototype.sayName = function () {
console.log(this.name)
}
function SubType (name, age) {
SuperType.call(this, name) // 通過(guò)構(gòu)造函數(shù)繼承實(shí)例屬性
this.age = age
}
SubType.prototype = Object.create(SuperType.prototype) //繼承父類共享方法
SubType.prototype.constructor = SubType //將SubType.prototype.constructor指針指回SubType函數(shù)
SubType.prototype.sayAge = function () {
console.log(this.age)
}
let obj = new SubType('jake', 22)
obj.sayName() // jake
obj.sayAge() // 22
console.log(obj instanceof SubType) // true
console.log(obj instanceof SuperType) // true
優(yōu)點(diǎn)
寄生組合繼承只調(diào)用了一次SuperType,所以更高效
避免了在SubType.prototype上創(chuàng)建了不必要的屬性
下面說(shuō)說(shuō)原型鏈和構(gòu)造函數(shù)的缺點(diǎn)
原型鏈
缺點(diǎn):當(dāng)原型鏈中包含引用類型值時(shí),原型屬性會(huì)被所有實(shí)例共享;
下面看一個(gè)例子
function SuperType() {
this.color = ['red', 'blue', 'green'];
}
//
function SubType() {};
//
SubType.prototype = new SuperType(); //繼承了SuperType
//
var instance1 = new SubType();
instance1.color.push('black');
console.log(instance1.color); //'red,blue,green,black'
//
var instance2 = new SubType();
console.log(instance2.color); //'red,blue,green,black'
借用構(gòu)造函數(shù)
缺點(diǎn):如果僅僅使用構(gòu)造函數(shù),方法都在構(gòu)造函數(shù)中定義,因此函數(shù)就無(wú)法實(shí)現(xiàn)復(fù)用了。而且,在超類型的原型中定義的方法,對(duì)于子類型而言也是不可見(jiàn)的。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript 通用loading動(dòng)畫(huà)效果實(shí)例代碼
這篇文章主要介紹了javascript 通用loading動(dòng)畫(huà)效果實(shí)例代碼,有需要的朋友可以參考一下2014-01-01
js實(shí)現(xiàn)簡(jiǎn)單隨機(jī)抽獎(jiǎng)的方法
這篇文章主要介紹了js實(shí)現(xiàn)簡(jiǎn)單隨機(jī)抽獎(jiǎng)的方法,涉及字符串的操作、setInterval定時(shí)調(diào)用等技巧,需要的朋友可以參考下2015-01-01
一文讀懂JS中的var/let/const和暫時(shí)性死區(qū)
這篇文章主要為大家詳細(xì)介紹了JavaScript中的var、let、const和暫時(shí)性死區(qū)的異同,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-02-02
javascript實(shí)現(xiàn)貪吃蛇經(jīng)典游戲
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)貪吃蛇經(jīng)典游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04
js-FCC算法-No repeats please字符串的全排列(詳解)
下面小編就為大家?guī)?lái)一篇js-FCC算法-No repeats please字符串的全排列(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
javascript 動(dòng)態(tài)修改css樣式方法匯總(四種方法)
為了達(dá)到某種特殊的效果我們需要用Javascript動(dòng)態(tài)的去更改某一個(gè)標(biāo)簽的Css屬性,如何動(dòng)態(tài)修改css樣式呢?面對(duì)這個(gè)問(wèn)題,小編帶領(lǐng)大家來(lái)解決javascript動(dòng)態(tài)修改css樣式,小伙伴們都快來(lái)學(xué)習(xí)吧2015-08-08

