zoukankan      html  css  js  c++  java
  • 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的整体架构就有了很好的理解,接下来的文章主要创建对象的方式。

    
    
  • 相关阅读:
    js函数的Json写法
    Bootstrap3和Bootstrap4区别
    Unicode编码是什么
    保留字是什么
    范仁义js课程---5、js字面量和变量
    什么是脚本语言
    ECMAScript 版本
    TortoiseGit上传代码到GitHub
    Android Studio快捷键
    Android 适配
  • 原文地址:https://www.cnblogs.com/gongOnTheWay/p/4840736.html
Copyright © 2011-2022 走看看