顶层对象在broswer环境中,指window对象;在node环境中指global对象。
在ES5中,顶层对象的属性与全局变量是等价的。
ES5中只有全局变量、函数内局部变量两种类型。
// 顶层变量
var aA = `hello,I am ok!`;
console.log('window.aA:',window.aA); // window.aA: hello,I am ok!
console.log('this.aA:',this.aA); // this.aA: hello,I am ok!
function test(){
console.log('顶层对象所有');
}
window.test(); // 顶层对象所有
this.test(); // 顶层对象所有
// 最好是试用通用的方法:this[顶层对象属性名]
// 在node环境下顶层非window,而是global
由上可见:顶层对象的属性赋值与全局变量的赋值是同一件事。
顶层对象的属性与全局变量相关,被认为是js语言中最大的设计败笔之一。
ES6中为了保持兼容性规定,var命令、function命令声明的全局变量依旧是顶层对象的属性;而let命令、const命令、class命令声明的全局变量不属于顶层对象属性。<