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

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

如果理解不了那么就可以利用之前说的另一个工具: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的整体架构就有了很好的理解,接下来的文章主要创建对象的方式。

 

 


posted @ 2015-09-26 15:06  Boris_Gong  阅读(1446)  评论(0编辑  收藏  举报