JavaScript 原型,原型链的特点

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() 创建的对象都可以访问这个方法。当我们试图访问 person1person2sayHello 方法时,JavaScript 首先会在这些对象自身上查找这个方法,如果没有找到,就会沿着原型链向上查找,直到找到 sayHello 方法或者到达原型链的顶端。

特点说明

JavaScript 的原型系统有以下特点:

  1. 动态性:可以在运行时动态地添加或删除对象的属性和方法。
  2. 共享性:所有的实例都可以共享它们的原型上的属性和方法,修改一个实例的属性会影响到其所有的实例。
  3. 链式查找:当访问一个对象的属性或方法时,如果这个对象自身没有这个属性或方法,JavaScript 会沿着原型链向上查找。
相关推荐
一直在学习的小白~3 分钟前
node_modules 明明写进 .gitignore,却还是被 push/commit 的情况
前端·javascript·vue.js
UrSpecial7 分钟前
Linux线程
linux·开发语言·c++
郝学胜-神的一滴8 分钟前
深入浅出 C++20:新特性与实践
开发语言·c++·程序人生·算法·c++20
闪电麦坤9526 分钟前
C/C++项目练习:命令行记账本
开发语言·c++
nightunderblackcat34 分钟前
新手向:从零理解LTP中文文本处理
前端·javascript·easyui
kyle~36 分钟前
python---PyInstaller(将Python脚本打包为可执行文件)
开发语言·前端·python·qt
User:你的影子41 分钟前
WPF ItemsControl 绑定
开发语言·前端·javascript
野生的编程萌新1 小时前
【C++深学日志】从0开始的C++生活
c语言·开发语言·c++·算法
知识分享小能手2 小时前
React学习教程,从入门到精通,React 构造函数(Constructor)完整语法知识点与案例详解(16)
前端·javascript·学习·react.js·架构·前端框架·vue
※※冰馨※※2 小时前
【c#】 使用winform如何将一个船的图标(ship.png)添加到资源文件
开发语言·windows·c#