JavaScript 的继承主要通过原型链来继承
继承的主要精髓就是 : 让一个对象的实例等于另一个原型对象
即:
Super.prototype = new Summer();
理解原型链就要理清 构造函数、原型对象和实例的关系
Js所有的构造函数都有个 prototype 属性,通过这个属性可以继承其他函数的方法,例如1:
function add(){
this.name = function(){
alert(“hello”);
}
}
function sum(){
this.age= function(){
alert(“world”);
}
}
sum.prototype = new add();
var ss = new sum();
//原型链关系
//实例对象ss 包含指向原型对象的内部指针 proto
ss.proto = sum.prototype ;
sum.prototype .proto = ==add.prototype;
add.prototype .proto = ==Object.prototype;
Object,prototype.proto = ==null
*_proto_*
sum()—–>sum 对象 ———–>add 对象
sum() 的 prototype 属性也指向add 对象
而sum对象其实就是原型对象, sum() 的 prototype 就是 sum的实例对象
总结:我所理解的 原型链 就相当于继承的作用,主要通过 prototype 属性来实现 继承,通过函数的 prototype 来指向另一个原型对象( new add() ),而这个函数的实例也就具备了另一个属性,这中间通过 proto 内部原型对象指针来实现