下面这张图就是js的整体结构图,咱们可以尝试用显性的prototype和隐形的[[prototype]]的概念来理解这个图中的每条路线:

js面向对象系列——关系图

如果理解不了那么就可以利用之前说的另一个工具:instanceof(它就是依赖原生链来实现)

例如:A InstantOf B 其实就是沿着实例对象的__proto__这条线来找,同时沿着函数对象的prototype这条线来找,如果两条线能找到同一个引用,即同一个对象,那么就返回true。如果找到终点还未重合,则返回false

以为他就是根据这个原理实现的,可以尝试模拟代码如下:

 

Object instanceof Object
// 为了方便表述,首先区分左侧表达式和右侧表达式
 ObjectL = Object, ObjectR = Object; 
 // 下面根据规范逐步推演
 O = ObjectR.prototype = Object.prototype 
 L = ObjectL.__proto__ = Function.prototype 
 // 第一次判断
 O != L 
 // 循环查找 L 是否还有 __proto__ 
 L = Function.prototype.__proto__ = Object.prototype 
 // 第二次判断
 O == L 
 // 返回 true

到此为止,js的整体架构就有了很好的理解,接下来的文章主要创建对象的方式。

 

 


相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-09-28
  • 2018-04-12
  • 2021-11-08
  • 2021-09-04
  • 2021-06-18
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-07-23
  • 2022-12-23
  • 2021-04-26
  • 2021-05-14
  • 2021-12-31
  • 2021-08-05
相关资源
相似解决方案