顶层对象的属性

本文为学习笔记;

原文链接 <<<<转载请注明原文出处!

顶层对象

  • 在浏览器环境指的是window对象;
  • 在 Node 指的是global对象。

ES5 之中,顶层对象的属性与全局变量是等价的,顶层对象的属性赋值与全局变量的赋值,是同一件事。
顶层对象的属性与全局变量挂钩,被认为是 JavaScript 语言最大的设计败笔之一。
这样的设计带来了几个很大的问题:

  • 首先是没法在编译时就报出变量未声明的错误,只有运行时才能知道(因为全局变量可能是顶层对象的属性创造的,而属性的创造是动态的);
  • 其次,程序员很容易不知不觉地就创建了全局变量(比如打字出错);
  • 最后,顶层对象的属性是到处可以读写的,这非常不利于模块化编程。
  • 另一方面,window 对象有实体含义,指的是浏览器的窗口对象,顶层对象是一个有实体含义的对象,也是不合适的。

ES6 为了改变这一点,一方面规定,为了保持兼容性,var 命令和 function 命令声明的全局变量,依旧是顶层对象的属性;另一方面规定,let 命令、const 命令、class 命令声明的全局变量,不属于顶层对象的属性。也就是说,从 ES6 开始,全局变量将逐步与顶层对象的属性脱钩。
如: 用 let 命令声明全局变量不是顶层对象的属性,用 window.变量名 返回undefined

global 对象

ES5 的顶层对象,本身也是一个问题,因为它在各种实现里面是不统一的。
现在很难找到一种方法,可以在所有情况下,都取到顶层对象。
现在有个提案:在语言标准的层面,引入 global 作为顶层对象。也就是说,在所有环境下,global 都是存在的,都可以从它拿到顶层对象。

HAVE A NICE DAY!
原文地址:https://www.cnblogs.com/apimhnkj/p/10123643.html