JavaScript 的原型(Prototype)和原型链(Prototype chain)是 JavaScript 面向对象编程中的重要概念。
原型(Prototype)
在 JavaScript 中,每个对象都有一个原型对象,而这个原型对象定义了这个对象的属性和方法。这个原型对象本身也可能会有自己的原型,这样就形成了一个链式结构,也就是所谓的“原型链”。
当在对象上查找一个属性时,如果这个对象自身没有这个属性,JavaScript 就会在该对象的原型(也就是它的 [[Prototype]]
属性)上查找,如果还没有,就会继续查找原型的原型,以此类推,直到找到对应的属性或者达到原型链的顶端(即 null)。
代码示例
function Person(name) {
this.name = name;
}
Person.prototype.sayHello = function() {
return `Hello, I'm ${this.name}`;
};
let person1 = new Person('Alice');
let person2 = new Person('Bob');
console.log(person1.sayHello()); // 输出 "Hello, I'm Alice"
console.log(person2.sayHello()); // 输出 "Hello, I'm Bob"
在这个例子中,sayHello
方法被定义在 Person
函数的 prototype
上,这样所有通过 new Person()
创建的对象都可以访问这个方法。当我们试图访问 person1
或 person2
的 sayHello
方法时,JavaScript 首先会在这些对象自身上查找这个方法,如果没有找到,就会沿着原型链向上查找,直到找到 sayHello
方法或者到达原型链的顶端。
特点说明
- 动态性:可以在运行时动态地添加或删除对象的属性和方法。
- 共享性:所有的实例都可以共享它们的原型上的属性和方法,修改一个实例的属性会影响到其所有的实例。
- 链式查找:当访问一个对象的属性或方法时,如果这个对象自身没有这个属性或方法,JavaScript 会沿着原型链向上查找。
原文地址:https://blog.csdn.net/m0_73481765/article/details/134623738
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_25204.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。