原型、原型链,显示原型,隐式原型
原型和原型链的概念
在JavaScript中,每个对象都有一个原型 prototype 和一个原型链 prototype chain 。原型是一个对象,它包含了共享的属性和方法。原型链是由一系列对象组成的链表,用于查找和继承属性和方法。
-
需要访问或调用一个对象的属性或方法时,JavaScript会首先查找对象本身是否具有该属性或方法,如果没有,则会沿着原型链一层层查找,直到找到或者到达原型链的末端。
显示原型和隐式原型的概念
- 显示原型是通过将一个对象赋值给另一个对象的prototype属性来进行设置的,用于实现对象之间的继承关系。
function Parent() {}
function Child() {}
Child.prototype = new Parent();
隐式原型是一个对象在创建时自动获得的,它指向该对象的构造函数的原型对象。
function Person(name) {
this.name = name;
}
Person.prototype.sayHello = function() {
console.log(`Hello, my name is ${this.name}.`);
};
var person1 = new Person('Bob');
person1.sayHello();
var person2 = new Person('Alice');
person2.sayHello();
console.log(person1.__proto__ === Person.prototype);
console.log(person2.__proto__ === Person.prototype);
以上代码中,我们定义了构造函数 Person 和它的原型方法 sayHello 。通过构造函数Person创建的实例 person1 和 person2 都可以调用 sayHello 方法,因为它们的隐式原型__proto__指向了 Person的原型对象。这样,我们就可以通过原型链的机制实现了对共享方法的复用。
以上是关于原型、原型链和显示原型与隐式原型的整理和示例注解