原型(Prototype)是JavaScript中一个非常重要的概念。每个JavaScript对象都有一个原型对象(Prototype Object),它是一个包含属性和方法的对象。当你访问一个对象的属性或方法时,如果这个对象本身没有这个属性或方法,JavaScript引擎就会沿着对象的原型链(Prototype Chain)向上查找,直到找到这个属性或方法为止。原型链是由每个对象的原型对象组成的一个链表,它连接了所有对象的原型对象。
JavaScript中的原型是通过构造函数(Constructor Function)来创建的。每个构造函数都有一个原型对象,它是该构造函数所创建的所有对象的原型对象。当你创建一个对象时,JavaScript引擎会自动将这个对象的原型对象指向构造函数的原型对象,这样就构成了原型链。
1.原型
每个JavaScript对象都有一个原型(prototype)属性,该属性指向另一个对象。这个对象的属性和方法可以被对象本身以及它的实例所继承。如果在一个对象上调用一个属性或方法,但该对象本身并没有定义该属性或方法,JavaScript会沿着原型链往上查找,直到找到该属性或方法或者原型链结束为止。
例如,如果我们有一个对象person,它的原型是Object.prototype,那么我们可以通过以下方式来定义person对象的属性:
var person = {
name: "John"
};
console.log(person.toString()); // 输出"[object Object]",因为toString()方法是从Object.prototype继承而来的
2.原型链
JavaScript中的每个对象都有一个原型对象,如果它的原型对象还有原型对象,就会形成一个原型链(prototype chain)。当我们在一个对象上访问一个属性或方法时,如果该对象本身没有定义该属性或方法,JavaScript会沿着原型链往上查找,直到找到该属性或方法或者原型链结束为止。
例如,如果我们有一个对象person,它的原型是Object.prototype,而Object.prototype的原型是null,那么我们可以通过以下方式来查找person对象的toString()方法:
var person = {
name: "John"
};
console.log(person.toString()); // 输出"[object Object]",因为toString()方法是从Object.prototype继承而来
// 查找person对象的toString()方法
// 在person对象中没有找到toString()方法
// 在Object.prototype中找到toString()方法,执行它
// 输出"[object Object]"