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
类的实例。