JavaScript中的原型链是一种实现对象间继承的机制。在JavaScript中,每个对象都有一个特殊的属性[[Prototype]]
,它是一个内部链接,指向另一个对象。这个被指向的对象就是原型对象。当试图访问一个对象的属性时,JavaScript会首先在该对象本身查找这个属性;如果没有找到,它会沿着原型链向上查找,直到找到该属性或者到达原型链的顶端(null
)。
通过原型链实现继承的基本思路是:子类对象共享父类原型上的属性和方法,从而实现代码复用。子类对象通过[[Prototype]]
属性指向父类的一个实例对象,这样它就可以访问到父类原型上的属性和方法。
这里有一个简单的例子来解释原型链和继承:
// 父类构造函数
function Parent() {
this.parentProperty = "parent property value";
}
// 父类原型方法
Parent.prototype.parentMethod = function() {
console.log("This is a parent method.");
};
// 子类构造函数
function Child() {
this.childProperty = "child property value";
}
// 设置子类原型对象为父类的一个实例对象,实现继承
Child.prototype = new Parent();
// 修复子类构造函数的指向问题
Child.prototype.constructor = Child;
// 子类原型方法
Child.prototype.childMethod = function() {
console.log("This is a child method.");
};
// 测试
var childInstance = new Child();
console.log(childInstance.parentProperty); // 输出 "parent property value"
childInstance.parentMethod(); // 输出 "This is a parent method."
childInstance.childMethod(); // 输出 "This is a child method."
在这个例子中,Child
类通过将Child.prototype
设置为Parent
的一个实例对象来实现对Parent
类的继承。这样,所有Child
类的实例都可以访问到Parent
类的属性和方法。同时,我们还需要修复Child.prototype.constructor
指向问题,以确保正确地创建Child
类的实例。