继承原理:实例中包含一个指向原型对象的内部指针
实现方法:让原型对象等于另一个类型的实例
关键点:
构造函数、原型对象、实例
实例属性、原型方法
构造关系、原型关系
自有属性、继承属性和方法
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.prototype
和cat
)都具有构造函数中的属性,实例和构造函数之间是构造关系;构造过程中也形成了原型关系:Mammal.prototype
是cat
的原型,Animal.prototype
是Mammal.prototype
的原型,实例通过原型链找到原型中的属性和方法。
自定义和构造函数的属性是自有属性,它们是对象本身的属性。来自继承的属性和方法是对象沿着原型链找到的,它们并不是对象本身的属性和方法。
实例继承到的方法的作用域是该实例对象内部的执行环境,可以访问实例能获取到的所有属性。通过this.property
的方式可以得到实例对象能够访问到的所有属性和方法,包括自有属性和继承的属性方法。demo中的实例对象cat
可以访问到在Animal
和Mammal
及其原型中定义的所有属性方法,这正是继承的意义所在。
验证:
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
文章不定期更新完善,如果能对你有一点点启发,我将不胜荣幸。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。