美文网首页
ES6顶层对象的属性

ES6顶层对象的属性

作者: 法西斯qwq | 来源:发表于2018-06-14 20:38 被阅读0次
    /*顶层对象,在浏览器环境指的是window对象,在 Node 指的是global 对象 ES5 之中,
     顶层对象的属性与全局变量是等价的*/
    

    /* window.a = 1; a // 1
    a = 2; window.a // 2 */

    上面代码中,顶层对象的属性赋值与全局变量的赋值,是同一事.

    顶层对象的属性与全局变量挂钩,被认为是 JavaScript 语言最大的设计败笔之一。
    这样的设计带来了几个很大的问题,首先是没法在编译时就报出变量未声明的错误,
    只有运行时才能知道(因为全局变量可能是顶层对象的属性创造的,而属性的创造是动态的);
    其次,程序员很容易不知不觉地就创建了全局变量(比如打字出错);
    最后,顶层对象的属性是到处可以读写的,这非常不利于模块化编程。
    另一方面,window对象有实体含义,指的是浏览器的窗口对象,顶层对象是一个有实体含义的对象,也是
    不合适的。
    ES6 为了改变这一点,一方面规定,为了保持兼容性,var命令和function命令声明的全局变量,
    依旧是顶层对象的属性;另一方面规定,let命令、const命令、class命令声明的全局变量,
    不属于顶层对象的属性。也就是说,从 ES6 开始,全局变量将逐步与顶层对象的属性脱钩
    /* var a = 1; window.a // 1
    如果在 Node 的 REPL 环境,可以写成 global.a 或者采用通用方法,写成 this.a;
    let b = 1; window.b // undefined */

    相关文章

      网友评论

          本文标题:ES6顶层对象的属性

          本文链接:https://www.haomeiwen.com/subject/vprueftx.html