原型链

本质

原型链的本质是链表,它的节点是各种原型对象

作用

原型链是 JavaScript 中实现继承的核心机制,通过__proto__链连接各种原型对象。

继承机制 :当访问对象属性时,若自身不存在,则沿原型链向上查找,直到找到或到达 null

概念

原型对象(Prototype):每个对象都有一个隐藏属性 __proto__,指向其构造函数的 prototype 对象。

构造函数 :当使用 new 调用时,会创建新实例的函数。其 prototype 属性将作为实例的原型。

例子

js 复制代码
// 这里在底层是用类Object的构造函数创造出的对象,等价于 new Object()
const obj = {};

// 实例的 __proto__ 指向构造函数的 prototype 
console.log(obj.__proto__ === Object.prototype); // true

这个例子里的原型链是这样的 obj -> Object.prototype -> null

js 复制代码
// 这里在底层是用类Array的构造函数创造出的对象,等价于 new Array()
const arr = [];

// 实例的 __proto__ 指向构造函数的 prototype
console.log(arr.__proto__ === Array.prototype);  // true

这个例子里的原型链是 arr -> Array.prototype -> Object.prototype -> null

js 复制代码
// 这里在底层是用类Function的构造函数创造出的对象,等价于 new Function()
const func = function a(){};

// 补充:箭头函数无 prototype 属性,但 __proto__ 也指向 Function.prototype

// 实例的 __proto__ 指向构造函数的 prototype
console.log(func.__proto__ === Function.prototype);  // true

这个例子里的原型链是这样的 func -> Function.prototype -> Object.prototype -> null

可以看出除了通过Object.create(null)直接创建的对象外,其他所有对象(包括函数、数组等)的原型链上都会出现Object.prototype,而原型链终点也都是 null

ps:

js 复制代码
// 这样创建出来的对象,原型链是 obj -> null
const obj = Object.create(null);

继承场景

使用现代语法(ES6 Class),语法糖 classextends ,底层基于原型链:

javascript 复制代码
class Parent {}
class Child extends Parent {}

const child = new Child();
// instanceof用来检测对象是否在原型链上
console.log(child instanceof Parent); // true
相关推荐
十字路口的火丁5 小时前
前端开发如何灵活使用 css 变量
前端
_志哥_5 小时前
深度解析:解决 backdrop-filter 与 border-radius 的圆角漏光问题
前端·javascript·html
南囝coding5 小时前
100% 用 AI 做完一个新项目,从 Plan 到 Finished 我学到了这些
前端·后端
qiao若huan喜5 小时前
10、webgl 基本概念 + 坐标系统 + 立方体
前端·javascript·信息可视化·webgl
前端一课5 小时前
Vue3 的 Composition API 和 Options API 有哪些区别?举例说明 Composition API 的优势。
前端
用户47949283569155 小时前
都说node.js是事件驱动的,什么是事件驱动?
前端·node.js
晴殇i5 小时前
前端架构中的中间层设计:构建稳健可维护的组件体系
前端·面试·代码规范
申阳6 小时前
Day 7:05. 基于Nuxt开发博客项目-首页开发
前端·后端·程序员
Crystal3286 小时前
App端用户每日弹出签到弹窗如何实现?(uniapp+Vue)
前端·vue.js
摸着石头过河的石头6 小时前
Service Worker 深度解析:让你的 Web 应用离线也能飞
前端·javascript·性能优化