js中構(gòu)造函數(shù)的幾種繼承模式淺析
一、原型鏈模式繼承
利用原型讓一個(gè)引用類型繼承另一個(gè)引用類型的屬性和方法 。
用的最多。
缺點(diǎn):不可傳參,不可多繼承。
-
function People(name, age) {//添加公有屬性
-
name = name || 'xiaolan';
-
-
-
-
}//創(chuàng)建一個(gè)名為People的類
-
People.prototype.eat = function() {//添加私有屬性
-
console.log(this.name + '賊能吃');
-
-
function Cat(color) {//創(chuàng)建一個(gè)名為Cat的類
-
-
-
Cat.prototype = new People('小叮當(dāng)', 200);//實(shí)例化一個(gè)People類,并賦值給Cat類的原型鏈
-
var cat = new Cat('藍(lán)白色')
-
console.log(cat.name)//'小叮當(dāng)'
-
cat.eat();//'小叮當(dāng)賊能吃'
二、混合模式繼承
用call的方法只能繼承私有屬性,所以再加一遍一遍原型鏈模式繼承,原型鏈模式繼承又把私有屬性和公有屬性都繼承了一遍。
-
function People(name, age) { //創(chuàng)建一個(gè)父級(jí)People類
-
name = name || 'xiaolan';
-
-
-
-
-
People.prototype.eat = function() {
-
console.log(this.name + '賊能吃');
-
-
-
function Cat(color, name, age) {
-
-
People.call(this, name, age); //通過call的形式繼承
-
//通過call(this),將People的指向改為Cat的實(shí)例
-
-
var cat = new Cat('藍(lán)白色', '小叮當(dāng)', 1);
-
console.log(cat.name);//'小叮當(dāng)'
-
cat.eat();//報(bào)錯(cuò),
-
//繼承不了公有屬性,所以cat.eat()會(huì)報(bào)錯(cuò);
為了繼承公有屬性,用原型鏈模式在把公有屬性和方法繼承過來,
-
function People(name, age) { //創(chuàng)建一個(gè)父級(jí)People類
-
name = name || 'xiaolan';
-
-
-
-
-
People.prototype.eat = function() {
-
console.log(this.name + '賊能吃');
-
-
-
function Cat(color, name, age) {
-
-
People.call(this, name, age); //通過call的形式繼承
-
//通過call(this),將People的指向改為Cat的實(shí)例
-
-
Cat.prototype = new People()
-
var cat = new Cat('藍(lán)白色', '小叮當(dāng)', 200)
-
-
console.log(cat.name); //'小叮當(dāng)',在原型鏈繼承的時(shí)候,就近原則,cat.name 先找到'小叮當(dāng)',就不往下找了
-
cat.eat(); //'小叮當(dāng)賊能吃'
三、拷貝繼承
優(yōu)點(diǎn):可以多繼承,可傳參;
缺點(diǎn):浪費(fèi)資源,不能判斷父級(jí);
-
function People(name, age) { //創(chuàng)建一個(gè)父級(jí)People類
-
name = name || 'xiaolan';
-
-
-
-
-
People.prototype.eat = function() {
-
console.log(this.name + '賊能吃');
-
-
-
function Cat(color, name, age) {
-
-
var people = new People(name, age) //實(shí)例化一個(gè)People類
-
-
this[i] = people[i]; //將people中的可枚舉屬性和方法遍歷并附給Cat類,公有屬性和私有屬性都是可枚舉屬性;
-
-
-
var cat = new Cat('藍(lán)白色', '小叮當(dāng)', 2);
-
console.log(cat.name); //小叮當(dāng)
-
cat.eat(); //小叮當(dāng)賊能吃
四、寄生組合方式繼承
優(yōu)點(diǎn):私有屬性和公有屬性都單獨(dú)繼承,可以傳參;
私有屬性可以多繼承,公有屬性不可多繼承;
-
function People(name, age) {
-
name = name || 'xiaolan';
-
-
-
-
-
People.prototype.eat = function() {
-
console.log(this.name + '賊能吃');
-
-
-
function Cat(color, name, age) {
-
-
People.call(this, name, age) //用call的形式把私有屬性繼承過來
-
-
-
function Fn() {} //創(chuàng)建一個(gè)中間構(gòu)造函數(shù),用來接收People的公有屬性,為了防止創(chuàng)建實(shí)例Cat實(shí)例是影響原來的people構(gòu)造函數(shù)
-
Fn.prototype = People.prototype;
-
Cat.prototype = new Fn(); //將中間構(gòu)造函數(shù)Fn繼承people的公有屬性傳給Cat的原型鏈
-
Cat.prototype.constructor = Cat; //由于上一步重置了Cat原型鏈的constructor屬性,所以要重新給賦回來;
-
var cat = new Cat('藍(lán)白色', '小叮當(dāng)', 3);
-
console.log(cat.name); //'小叮當(dāng)'
-
cat.eat() //'小叮當(dāng)賊能吃
注:若有不嚴(yán)謹(jǐn)與錯(cuò)誤的地方,請(qǐng)多指教!
-
-
-
-
-
-
-