目录

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;
  • 对象的原型是构造函数的原型;
  • 函数可以分为函数和对象两种原型,要看具体是怎么创建的。
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
风无雨26 分钟前
react antd 项目报错Warning: Each child in a list should have a unique “key“prop
前端·react.js·前端框架
人无远虑必有近忧!27 分钟前
video标签播放mp4格式视频只有声音没有图像的问题
前端·video
Qlittleboy3 小时前
windows如何安装wkhtmltoimage 给PHP使用根据HTML生成图片
开发语言·windows·php
水w3 小时前
【Android Studio】解决报错问题Algorithm HmacPBESHA256 not available
android·开发语言·android studio
冷琅辞4 小时前
Elixir语言的云计算
开发语言·后端·golang
记得早睡~4 小时前
leetcode51-N皇后
javascript·算法·leetcode·typescript
Mryan20055 小时前
解决GraalVM Native Maven Plugin错误:JAVA_HOME未指向GraalVM Distribution
java·开发语言·spring boot·maven
Naomi5215 小时前
自定义汇编语言(Custom Assembly Language) 和 Unix & Git
服务器·开发语言·git·unix
烂蜻蜓5 小时前
C 语言命令行参数:让程序交互更灵活
c语言·开发语言·交互
zm-v-159304339865 小时前
解锁 DeepSeek 与 Matlab:攻克科研难题的技术利刃
开发语言·matlab·信息可视化