类的创建和继承

101 阅读2分钟

(1)类的创建(es5):new 一个 function,在这个 function 的 prototype 里面增加属性和

方法。

下面来创建一个 Animal 类:

// 定义一个动物类

function Animal(name) {

    // 属性

    this.name = name || 'Animal';

    // 实例方法

    this.sleep = function() {

        console.log(this.name + '正在睡觉!');

    }

}

// 原型方法

Animal.prototype.eat = function(food) {

    console.log(this.name + '正在吃:' + food);

};

这样就生成了一个 Animal 类,实力化生成对象后,有方法和属性。

(2)类的继承——原型链继承

//原型链继承

function Cat() {}

Cat.prototype = new Animal();

Cat.prototype.name = 'cat';

// Test Code

var cat = new Cat();

console.log(cat.name);

console.log(cat.eat('fish'));

console.log(cat.sleep());

console.log(cat instanceof Animal); //true

console.log(cat instanceof Cat); //true

介绍:在这里我们可以看到 new 了一个空对象,这个空对象指向 Animal 并且 Cat.prototype

指向了这个空对象,这种就是基于原型链的继承。

特点:基于原型链,既是父类的实例,也是子类的实例

缺点:无法实现多继承

(3)构造继承:使用父类的构造函数来增强子类实例,等于是复制父类的实例属性给

//子类(没用到原型)

function Cat(name) {

    Animal.call(this);

    this.name = name || 'Tom';

}

// Test Code

var cat = new Cat();

console.log(cat.name);

console.log(cat.sleep());

console.log(cat instanceof Animal); // false

console.log(cat instanceof Cat); // true

特点:可以实现多继承

缺点:只能继承父类实例的属性和方法,不能继承原型上的属性和方法。

(4)实例继承和拷贝继承

实例继承:为父类实例添加新特性,作为子类实例返回

拷贝继承:拷贝父类元素上的属性和方法

上述两个实用性不强,不一一举例。

(5)组合继承:相当于构造继承和原型链继承的组合体。通过调用父类构造,继承父

类的属性并保留传参的优点,然后通过将父类实例作为子类原型,实现函数复用

function Cat(name) {

    Animal.call(this);

    this.name = name || 'Tom';

}

Cat.prototype = new Animal();

Cat.prototype.constructor = Cat;

// Test Code

var cat = new Cat();

console.log(cat.name);

console.log(cat.sleep());

console.log(cat instanceof Animal); // true

console.log(cat instanceof Cat); // true

特点:可以继承实例属性/方法,也可以继承原型属性/方法

缺点:调用了两次父类构造函数,生成了两份实例

(6)寄生组合继承:通过寄生方式,砍掉父类的实例属性,这样,在调用两次父类的

构造的时候,就不会初始化两次实例方法/属性

function Cat(name) {

    Animal.call(this);

    this.name = name || 'Tom';

}

(function() {

    // 创建一个没有实例方法的类

    var Super = function() {};

    Super.prototype = Animal.prototype;

    //将实例作为子类的原型

    Cat.prototype = new Super();

})();

// Test Code

var cat = new Cat();

console.log(cat.name);

console.log(cat.sleep());

console.log(cat instanceof Animal); // true

console.log(cat instanceof Cat);

我的博客只写前端博文,点击我去看更多喜欢的前端博文,欢迎大家一起讨论学习!【https://blog.csdn.net/qq_29101285?spm=1011.2266.3001.5343】