js之原型链

在JavaScript中,原型链是一种用于实现继承和属性查找的机制。每个对象都有一个内部属性[[Prototype]],这个属性指向创建该对象时使用的构造函数的"prototype"属性。对象的方法和属性定义在它的原型对象上。

1.原型(Prototypes)

在JavaScript中,所有的事物都是对象。这些对象都由一个构造函数创建。例如,当你创建一个数组,实际上调用的是内置的Array构造函数。

每个构造函数都有一个名为"prototype"的属性,这个属性指向一个对象,也就是原型对象。此原型对象自己也有一个属性,称为"constructor",它反向指回构造函数。

javascript 复制代码
function Person() {}

var person1 = new Person();

console.log(Person.prototype) // 输出: { constructor: ƒ Person(), __proto__: Object }
console.log(Person.prototype.constructor === Person) // 输出:true

2.原型链(Prototype Chain)

当你试图访问一个对象的属性时,JavaScript首先在对象本身查找这个属性。如果找不到,它就会去对象的[[Prototype]](也就是它的构造函数的prototype)中查找,然后是该[[Prototype]]的[[Prototype]],以此类推,直到找到属性或查找到null(原型链的终点)。这个查找过程就是原型链。

javascript 复制代码
function Person() {}
Person.prototype.name = "John";

var person1 = new Person();

console.log(person1.name) // 输出:"John"

3.原型链经典图

可以看出以下几点:

  • 构造函数的原型的构造是他本身;
  • 原型链的终点是null;
  • 对象的原型是构造函数的原型;
  • 函数可以分为函数和对象两种原型,要看具体是怎么创建的。
相关推荐
活宝小娜4 分钟前
vue不刷新浏览器更新页面的方法
前端·javascript·vue.js
程序视点7 分钟前
【Vue3新工具】Pinia.js:提升开发效率,更轻量、更高效的状态管理方案!
前端·javascript·vue.js·typescript·vue·ecmascript
coldriversnow8 分钟前
在Vue中,vue document.onkeydown 无效
前端·javascript·vue.js
我开心就好o9 分钟前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
----云烟----36 分钟前
QT中QString类的各种使用
开发语言·qt
lsx20240641 分钟前
SQL SELECT 语句:基础与进阶应用
开发语言
开心工作室_kaic1 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā1 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
向宇it1 小时前
【unity小技巧】unity 什么是反射?反射的作用?反射的使用场景?反射的缺点?常用的反射操作?反射常见示例
开发语言·游戏·unity·c#·游戏引擎
武子康1 小时前
Java-06 深入浅出 MyBatis - 一对一模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据仓库·sql·mybatis·springboot·springcloud