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

js顶层对象的属性

作者: fighterboy | 来源:发表于2017-05-24 16:32 被阅读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;

// 如果在Node的REPL环境,可以写成global.a

// 或者采用通用方法,写成this.a

console.log(window.a)    // 1

let b = 2;

console.log(window.b);  //undefined

上面代码中,全局变量a由var命令声明,所以它是顶层对象的属性;全局变量b由let命令声明,所以它不是顶层对象的属性,返回undefined。

相关文章

  • js顶层对象的属性

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

  • 2018-06-28 ecma 6 (顶层对象 的 属性)

    顶层对象的属性

  • 顶层对象的属性

    顶层对象属性ES6 之后 var和function命令声明全局变量,依然是顶层对象的属性但是,let const ...

  • 顶层对象属性与全局变量

    顶层对象,在浏览器环境指的是window对象,在 Node 指的是global对象。ES5 之中,顶层对象的属性与...

  • (阮一峰)顶层对象的属性

    顶层对象,在浏览器环境指的是window对象,在 Node 指的是global对象。ES5 之中,顶层对象的属性与...

  • JS获取顶层对象

    方法一 ‘(typeof window !== 'undefined' ? window : (typeof pr...

  • Java与Kotlin的区别

    Java:面向对象编程,顶层是类ClassKotlin:函数式编程,顶层是函数,顶层属性,类存在于函数中在java...

  • 封装JS方法_增删改查

    库把建立一个对象,作为封装JS函数方法的库,绑定在最顶层元素window下 使用原始的函数方法进行添加带属性有文本...

  • JS—浏览器对象

    1.window对象是最顶层的对象2.window对象有6大属性(document,frames,history,...

  • 对象

    js对象 js对象是j's的基本数据类型, js中的对象是动态的, 可以新增属性,也可以删除属性。 1.获取时间 ...

网友评论

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

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