关于var、let的顶层对象的属性

简介: 关于var、let的顶层对象的属性

正文


顶层对象 ,在浏览器环境指的是 window 对象,在 Node 指的是 global 对象。ES5 之中,顶层对象的属性与全局变量是等价的。

window.a = 1;
console.log(a);  // 1
a = 2;
console.log(window.a);  // 2


在上面代码中,顶级对象的属性赋值与全局变量的赋值,是同一件事。


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


ES6 为了改变这一点,一方面规定,为了保持兼容性,varfunction 声明的全局变量,依旧是顶层对象的属性;另一方面规定,letconstclass 声明的全局变量,不属于顶层对象的属性。也就是说,从 ES6 开始,全局变量将逐步与顶层对象的属性脱钩。

var a = 1;
// 如果在 Node 的 REPL 环境,可以写成 global.a
// 或者采用通用方法,写成 this.a
console.log(window.a);  // 1
console.log(this.a);    // 1
let b = 1;
console.log(window.b);  // undefined
console.log(this.b);    // undefined


上面代码中,全局变量 avar 命令声明,所以它是顶层对象的属性;全局变量 blet 命令声明,所以它不是顶层对象的属性,返回 undefined

目录
相关文章
|
9月前
|
JavaScript 前端开发
如何删除对象中的属性?如何想对象中添加属性?
如何删除对象中的属性?如何想对象中添加属性?
83 0
|
3月前
多层嵌套对象的解构赋值时,如果对象的属性名相同怎么办?
在多层嵌套对象的解构赋值中遇到属性名相同时,使用别名是一种有效的解决方法,它能够帮助我们准确地提取和使用对象中的数据,避免变量名冲突,提高代码的质量和可维护性。
85 7
|
9月前
|
JavaScript
为什么data属性是一个函数而不是一个对象?
为什么data属性是一个函数而不是一个对象?
107 1
|
JavaScript
JS——根据对象数组的某个属性值找到指定的对象
JS——根据对象数组的某个属性值找到指定的对象
537 0
|
存储 JavaScript
如何使用 ref 属性获取子组件实例对象?
如何使用 ref 属性获取子组件实例对象?
164 0
对象定义-解构-枚举属性遍历以及对象内函数
对象定义-解构-枚举属性遍历以及对象内函数
90 0
|
JavaScript
js获取对象属性的两种方法,object.属性名,[‘属性名’ ]
js获取对象属性的两种方法,object.属性名,[‘属性名’ ]
1031 0
js获取对象属性的两种方法,object.属性名,[‘属性名’ ]
lodash遍历并继承对象属性,自定义分配
lodash遍历并继承对象属性,自定义分配
152 0
lodash创建一个函数属性名称的数组,包含继承属性
lodash创建一个函数属性名称的数组,包含继承属性
101 0
lodash判断对象的直接或继承属性是否存在
lodash判断对象的直接或继承属性是否存在
199 0