网易:所有的对象最终都会继承自 Object.prototype ? ——原型链(一)详细讲解!

前言

在上一篇文章中我们讲到了原型,而原型分为函数原型和对象原型。今天我们来聊聊JS中的原型链,原型链跟原型的关系十分密切。如果对原型还不太了解的小伙伴,可以看看我上一篇文章,配合本篇食用效果更佳哦~

文章链接在此: 原型

正文

函数有一个原型,我们称为显示原型。而对象也有一个原型,我们称为隐式原型。我们知道,函数的原型因为有属性和方法,那么它也是一个对象。既然是对象,那么它是不是也有对象原型,那么函数的显示原型的隐式原型又是什么呢?

这里可能有点绕,我们来看张图理解一下:

实例对象p由构造函数Person创建,如图中绿色箭头所示,当访问p中的属性时,先找对象显示具有的属性,如图中小的黑色箭头,这里假设p没有任何显示属性,然后去找p的隐式原型,而p的隐式原型就等于构造函数Person的显示原型,所以就去构造函数Person的显示原型中查找,如图中大的黑色箭头。因为函数的显示原型同样是一个对象,所以它也存在着隐式原型,当我们在Person的显示原型中没有查找到属性时,就从Person的显示原型的隐式原型中查找,而对象的隐式原型又等于构造函数的显示原型,而这里Person的显示原型这个对象是由new Object()这个构造函数创造的,所以我们相当于去查找Object的显示原型。

那小伙伴们可能会有一个疑问,Object的显示原型也是一个对象,它也有隐式原型,那么它也是被构造函数创建的,那就会一直往上查找,不是子子孙孙无穷尽也?所以,规定,Object.prototype的隐式原型为null,查询到这里停止。

引出原型链的概念:

原型链

顺着对象的隐式原型不断地向上查找上一级的隐式原型,直到找到目标或者一直到null,这种查找关系叫做原型链

我们来看一道例题:

js 复制代码
  Ground.prototype.lastName = '贺'
  function Ground() {

  }
  var ground = new Ground()

  Father.prototype = ground
  function Father() {
    this.name = 'jingwei'
  }
  var father = new Father()

  Son.prototype = father
  function Son() {
    this.hobbit = 'reading'
  }
  var son = new Son()

  console.log(son.name);
  console.log(son.lastName);

我们来看看会输出什么:

这里的访问规则就用到了我们刚刚所讲的原型链,我们来分析一下:

当访问son.name时,先会找对象的显示属性,这里的显示属性只有hobbit,然后查找p的隐式原型也就是Son的显示原型,这里发现Son.prototype = father,我们再来查找father这个对象中的显示属性,发现了this.name = 'jingwei',所以这里输出 jingwei

当访问son.lastName时,先查找对象的显示属性,这里的显示属性只有hobbit,然后查找p的隐式原型也就是Son的显示原型,这里发现Son.prototype = father,我们再来查找father这个对象中的显示属性,发现没有lastName这个属性,所以查找father的隐式原型,也就是构造函数Father的显示原型,我们发现Father.prototype = ground,所以查找ground这个对象的显示属性,没有找到,再去找ground的隐式原型也就是Ground的显示原型,发现Ground.prototype.lastName = '贺',所以输出 贺

再下一节我们会再深入一下原型链并且讲一讲网易的面试题,小伙伴们可以关注一下我

我们先放出网易的面试题,小伙伴们可以先思考一下:

网易:所有的对象最终都会继承自 Object.prototype ?

js 复制代码
<script>
    //Object.create()

    let obj = {
        a: 1
    }

    let obj2 = Object.create(null)

    //网易:所有的对象最终都会继承自 Object.prototype ?
</script>

为什么我们用这个例子,对象最终不会继承自Object.prototype

总结

顺着对象的隐式原型不断地向上查找上一级的隐式原型,直到找到目标或者一直到null,这种查找关系叫做原型链

Object.prototype的隐式原型为null

今天的内容就到这啦,如果你觉得小编写的还不错的话,或者对你有所启发,请给小编一个辛苦的赞吧

相关推荐
Mr.Jessy9 小时前
JavaScript高级:构造函数与原型
开发语言·前端·javascript·学习·ecmascript
白兰地空瓶11 小时前
🚀你以为你在写 React?其实你在“搭一套前端操作系统”
前端·react.js
爱上妖精的尾巴12 小时前
6-4 WPS JS宏 不重复随机取值应用
开发语言·前端·javascript
似水流年QC12 小时前
深入探索 WebHID:Web 标准下的硬件交互实现
前端·交互·webhid
陪我去看海12 小时前
测试 mcp
前端
speedoooo13 小时前
在现有App里嵌入一个AI协作者
前端·ui·小程序·前端框架·web app
全栈胖叔叔-瓜州13 小时前
关于llamasharp 大模型多轮对话,模型对话无法终止,或者输出角色标识User:,或者System等角色标识问题。
前端·人工智能
三七吃山漆13 小时前
攻防世界——wife_wife
前端·javascript·web安全·网络安全·ctf
用户479492835691513 小时前
面试官问"try-catch影响性能吗",我用数据打脸
前端·javascript·面试
GISer_Jing14 小时前
前端营销技术实战:数据+AI实战指南
前端·javascript·人工智能