原型链的原貌

原型链的原貌

先注入一个知识点:函数的本质是一个可以被调用的对象

js 复制代码
    function sum1(a,b){
        return a + b
    }
    
    const sum2 = new Function("a","b","return a+b")
    
    // 以上是一样的效果

下面用一个简单例子来解释原型链:

js 复制代码
    function A(){} //函数
    
    const a = new A()  //通过new得到的实例
    
    a.__proto__ === A.prototype   //会得到true

每个函数都有一个prototype属性,表示这个函数的原型对象实例的__proto__会指向函数的原型

scss 复制代码
如下图:(红色箭头 实例,绿色箭头 原型,黑色箭头 隐式原型)

得到这个基础模型后,我们接着一个一个看,先看A.prototype是哪来的呢?A.prototype 是一个普通对象,那么它实际上就是通过new Objcet得到的 。因此它的函数就是Object,Object也有属于它自己的prototype原型。但接下来会有一个特殊点,Object.prototype的隐式原型则为null,不然就无穷无尽下去了。

那么我们所说的原型链 就是图中的黑色箭头。比如这里问:

对象a的原型链: a->A.prototype->Object.prototype->null 。

ok接下来关注点到Object身上,它本身也是一个函数,所以它是被new Function得到的。而同样的Function也有自己的prototype原型。

好,接下来有一个理解起来有点像悖论的知识。我们在前面知道了A.prototype是通过new Object出来的,那么这里的Function.prototype 也是通过new Object出来的,因此Function.prototype的隐式原型也指向了Object.prototype。

而Function哪来的呢?它是特殊情况,可以理解为JS引擎在启动时,它就已经被安放了,它的隐式原型就直接指向自己的prototype原型。

现在看回到A函数,那么A实际上也是通过new Function得到的,接下来连线(看着乱,但是我们找原型链 只看黑色的链路)

所以每个我们自己定义的A函数既有Function.prototype里的成员 (A.bind、A.call等等)又有Object.prototype里的成员(toString、valueOf等等)。

相关推荐
掘金一周4 小时前
企业中要做智能体,最佳的方案是什么? | 沸点周刊 6.18
前端·人工智能·ai编程
Darling噜啦啦4 小时前
CSS 3D 变换与 Flex 布局实战:从零打造旋转立方体
前端·css
十九画生4 小时前
parentID ``` JavaScript 是区分大小写的,所以这两个不是同一个字段。 第二,`parent` 没有声明。 应该先写: `
javascript
秃头网友小李4 小时前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
鱼人4 小时前
CSS 变量:一个变量救你一百次复制粘贴
前端
长大19884 小时前
CSS 到底是什么?和 HTML 的区别一次讲清楚
前端
禅思院4 小时前
路由性能优化终极指南:从懒加载漏洞到边缘渲染的架构跃迁
前端·架构·前端框架
怕浪猫4 小时前
Electron 开发实战(十六):总结与展望|生态现状、框架对比、行业趋势与学习指南
前端·javascript·electron
文心快码BaiduComate4 小时前
Comate 搭载GLM-5.2:百万上下文,稳定支撑长程任务
前端·程序员·开源
星栈4 小时前
Dioxus 的 `rsx!` 语法:如果你会 React,上手确实特别快
前端·前端框架