• es6读书笔记(四)——顶层对象


    • ES6一方面规定,为了保持兼容性,var命令和function命令声明的全局变量,依旧是顶层对象的属性;另一方面规定,let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性。也就是说,从ES6开始,全局变量将逐步与顶层对象的属性脱钩。
      var a = 1;
      // 如果在Node的REPL环境,可以写成global.a
      // 或者采用通用方法,写成this.a
      window.a // 1
      
      let b = 1;
      window.b // undefined

    ES5之中,顶层对象的属性与全局变量是等价的。

    window.a = 1;
    a // 1
    
    a = 2;
    window.a // 2
    View Code

    顶层对象的属性与全局变量挂钩,被认为是JavaScript语言最大的设计败笔之一。

    这样的设计带来了几个很大的问题,

    首先是没法在编译时就报出变量未声明的错误,只有运行时才能知道(因为全局变量可能是顶层对象的属性创造的,而属性的创造是动态的);

    其次,程序员很容易不知不觉地就创建了全局变量(比如打字出错);

    最后,顶层对象的属性是到处可以读写的,这非常不利于模块化编程。

    另一方面,window对象有实体含义,指的是浏览器的窗口对象,顶层对象是一个有实体含义的对象,也是不合适的。

    • ES5的顶层对象,本身也是一个问题,因为它在各种实现里面是不统一的。(浏览器、node、Web Worker)
    • (这里很重要)
      • 全局环境中,this会返回顶层对象。但是,Node模块和ES6模块中,this返回的是当前模块。
      • 函数里面的this,如果函数不是作为对象的方法运行,而是单纯作为函数运行,this会指向顶层对象。但是,严格模式下,这时this会返回undefined
      • 不管是严格模式,还是普通模式,new Function('return this')(),总是会返回全局对象。但是,如果浏览器用了CSP(Content Security Policy,内容安全政策),那么evalnew Function这些方法都可能无法使用。
  • 相关阅读:
    Kafka与RabbitMQ区别
    Illegal instruction 问题的解决方法
    Debian 6 , 十个串口为什么只识别到了 6个 剩下4 个被禁止了
    微信二次认证 C#
    修改XtraMessageBox的内容字体大小
    svn: E155017: Checksum mismatch while updating 校验错误的解决方法
    再生龙恢复分区后修复引导或debian linux修复引导 三部曲
    Clonezilla制作镜像时报错: errextfsclone.c:bitmap free count err
    我用windows live Writer 写个日志试试看
    Debian下签名无法验证
  • 原文地址:https://www.cnblogs.com/tblj/p/6916628.html
Copyright © 2020-2023  润新知