1

继承原理:实例中包含一个指向原型对象的内部指针

实现方法:让原型对象等于另一个类型的实例

关键点:

  1. 构造函数、原型对象、实例

  2. 实例属性、原型方法

  3. 构造关系、原型关系

  4. 自有属性、继承属性和方法

demo:

//构造器
function Animal() {
    this.animal = 'animal';
};
function Mammal() {
    this.mammal = 'mammal';
};
var cat;

//原型链
Mammal.prototype = new Animal();
cat = new Mammal();

//添加属性和方法
Animal.prototype.isAnimal = true;
Animal.prototype.sayAnimal = function() {
    alert('Is it ' + this.animal + '? ' + this.isAnimal);
};
Mammal.prototype.isMammal = true;
Mammal.prototype.sayMammal = function() {
    alert('Is it a ' + this.mammal + '? ' + this.isMammal);
};

先来看看每个对象都能访问到哪些属性和方法:

Animal.prototype:

isAnimal    //自定义
sayAnimal()    //自定义

Mammal.prototype:

isMammal    //自定义
sayMammal()    //自定义
animal    //来自构造函数
isAnimal    //来自继承
sayAnimal()    //来自继承

cat:

mammal    //来自构造函数
isMammal    //来自继承
sayMammal()    //来自继承
animal    //来自继承
isAnimal    //来自继承
sayAnimal()    //来自继承

在这个demo中,有两对构造关系和两对继承关系(不考虑Object)。每一个通过构造函数实例化的对象(Mammal.prototypecat)都具有构造函数中的属性,实例和构造函数之间是构造关系;构造过程中也形成了原型关系Mammal.prototypecat的原型,Animal.prototypeMammal.prototype的原型,实例通过原型链找到原型中的属性和方法。

自定义和构造函数的属性是自有属性,它们是对象本身的属性。来自继承的属性和方法是对象沿着原型链找到的,它们并不是对象本身的属性和方法

实例继承到的方法的作用域是该实例对象内部的执行环境,可以访问实例能获取到的所有属性。通过this.property的方式可以得到实例对象能够访问到的所有属性和方法,包括自有属性和继承的属性方法。demo中的实例对象cat可以访问到在AnimalMammal及其原型中定义的所有属性方法,这正是继承的意义所在。

验证:

console.log(cat.mammal);    //mammal
console.log(cat.isMammal);    //true
console.log(cat.sayMammal());    //Is it mammal? true
console.log(cat.animal);    //animal
console.log(cat.isAnimal);    //true
console.log(cat.sayAnimal());    //Is it animal? true

转载请注明出处:https://segmentfault.com/a/1190000004550787

文章不定期更新完善,如果能对你有一点点启发,我将不胜荣幸。


hiYoHoo
2.2k 声望23 粉丝