js 原型链 prototype 产生原因及具体实现原理

原型链笔记

  • 原型链是为什么产生的?
  • 我们应该怎么理解他呢?

原型链的产生, 是为了解决 编程语言中继承和复用的问题, 相较于 java、或是python, js也是一门编程语言所以也要解决这两个问题,但是解决的办法又不能和已有的两种语言一样 所以产生了原型链这个概念。

简单来说 原型链的产生就是为了解决 编程语言中的继承和复用问题

  • 那我们要如何自己手写一个简单的原型链呢?

首先我们要知道获取原型的几种方法都有哪些

1.通过实例对象获取:const arr = new Array(); arr.__proto__ [解释:其中的__proto__属性是人为定义的 它指向原型对象]

2.通过构造函数获取:function Constructor(){}; Constructor.prototype[解释:在构造函数中有默认的属性,👇构造函数属性值]

3.通过方法获取:Object.getPrototypeOf(构造函数) [解释:通过对象方法 get 到prototype 方法参数为构造函数]

js 复制代码
//原型对象中最为重要的两个属性 
// constructor:赋值当前构造函数, 
// __proto__:赋值 当前原型的上一级原型 [最顶层原型对象 的上一级是null]
const prototypes = { 
  // 当前构造函数
  constructor: A,
  // 上级构造函数
  __proto__ : null
}

// 创建一级构造函数↓
function A() {
  this.a = 123
  // 函数中自定义的属性__proto__ 属性;存放当前构造函数的原型对象
  this.__proto__ = A.prototype
}
// 将自定义原型对象替换默认原型对象
A.prototype = prototypes
// 实例化, 查看结果
const a = new A()
console.log(a, a.__proto__);

// 创建二级 构造函数↓
function B() {
  this.b = 234
  // 函数中自定义的属性__proto__ 属性;存放当前构造函数的原型对象
  this.__proto__ = B.prototype
}
// 绑定 原型对象必备的两个属性值
B.prototype.constructor = B
B.prototype.__proto__ = a
const b = new B()
// 实例化对象并查看结果
console.log(b)

总结:原型是如何形成原型链

原型 prototype == [[ prototype ]] 【不全等】 其中 prototype 是原型对象

而 [[ prototype ]] 是浏览器内部的属性的值, 也是处理过之后展示给用户的的原型对象【其中并不会直接展示__proto__ 这个属性】

原型对象:prototype

其中有两个 最为重要的值

  1. constructor : constructor我们用来和构造函数来相互转化,他的赋值是当前 原型对象的构造函数的回调
  2. proto : 有两个地方出现了它【构造函数人为添加 为当前构造函数的回调,prototype属性中的 proto 用来指向上一级的实例对象 也是形成链式解构的关键属性】

参考连接:js 从语言设计的角度问:为什么要设计原型prototype ? - 掘金

相关推荐
海的诗篇_2 小时前
前端开发面试题总结-原生小程序部分
前端·javascript·面试·小程序·vue·html
黄瓜沾糖吃3 小时前
大佬们指点一下倒计时有什么问题吗?
前端·javascript
温轻舟3 小时前
3D词云图
前端·javascript·3d·交互·词云图·温轻舟
浩龙不eMo3 小时前
✅ Lodash 常用函数精选(按用途分类)
前端·javascript
爱分享的程序员3 小时前
前端面试专栏-算法篇:17. 排序算法
前端·javascript·node.js
pe7er4 小时前
使用 Vue 官方脚手架创建项目时遇到 Node 18 报错问题的排查与解决
前端·javascript·vue.js
pe7er4 小时前
使用 types / typings 实现全局 TypeScript 类型定义,无需 import/export
前端·javascript·vue.js
islandzzzz5 小时前
(第二篇)HMTL+CSS+JS-新手小白循序渐进案例入门
前端·javascript·css·html
喝拿铁写前端5 小时前
前端实战优化:在中后台系统中用语义化映射替代 if-else,告别魔法数字的心智负担
前端·javascript·架构
超人不会飛5 小时前
就着HTTP聊聊SSE的前世今生
前端·javascript·http