ES6顶层对象、global对象实例分析


Posted in Javascript onJune 14, 2019

本文实例讲述了ES6顶层对象、global对象。分享给大家供大家参考,具体如下:

顶层对象

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

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

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

ES6规定,var命令和function命令声明的全局变量,依旧是顶层对象的属性;let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性。

也就是说,从ES6开始,全局变量将逐步和顶层对象的属性脱钩

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

global对象

ES5的顶层对象,本身也是一个问题,因为它在各种实现里面不统一。

1.浏览器里面,顶层对象是window,但是Node和Web Worker没有window

2.浏览器和Web Worker里面,self也指向顶层对象,但是Node没有self

3.Node里面,顶层对象是global,但其他环境都不支持

同一段代码为了能够在各种环境,都能取到顶层对象,现在一般是使用this变量,但是有局限性。很难找到一种方法,可以在所有的情况下,都取到顶层对象。下面是2种勉强可以使用的方法:

// 方法1
(typeof window !== 'undefined' ? window : (typeof process === 'object' && typeof require === 'function' && typeof global === 'object') ? global : this);
// 方法2
var getGlobal = function (){
 if(typeof self !== 'undefined'){return self;}
 if(typeof window !== 'undefined'){return window;}
 if(typeof global !== 'undefined'){return global;}
 throw new Error('unable to locate global object');
};

现在有一个提案,在语言标准的层面,引入global作为顶层对象。也就是说,在所有环境下,global都是存在的,都可以冲它拿到顶层对象。

// CommonJS的写法
var global = require('system.global')();
// ES6模块的写法
import getGlobal from 'system.global';
const global = getGlobal();

上面的代码将顶层对象放入变量global

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Easyui form combobox省市区三级联动
Jan 13 Javascript
Java框架SSH结合Easyui控件实现省市县三级联动示例解析
Jun 12 Javascript
javascript回到顶部特效
Jul 30 Javascript
用AngularJS来实现监察表单按钮的禁用效果
Nov 02 Javascript
自己封装的一个原生JS拖动方法(推荐)
Nov 22 Javascript
js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换
Dec 06 Javascript
JS实现图片预加载之无序预加载功能代码
May 12 Javascript
javascript数组拍平方法总结
Jan 20 Javascript
几个你不知道的技巧助你写出更优雅的vue.js代码
Jun 11 Javascript
对vuejs的v-for遍历、v-bind动态改变值、v-if进行判断的实例讲解
Aug 27 Javascript
微信小程序录音实现功能并上传(使用node解析接收)
Feb 26 Javascript
如何阻止移动端浏览器点击图片浏览
Aug 29 Javascript
ES6数组与对象的解构赋值详解
Jun 14 #Javascript
简单了解Ajax表单序列化的实现方法
Jun 14 #Javascript
通过JS深度判断两个对象字段相同
Jun 14 #Javascript
CKEditor 4.4.1 添加代码高亮显示插件功能教程【使用官方推荐Code Snippet插件】
Jun 14 #Javascript
利用JavaScript将Excel转换为JSON示例代码
Jun 14 #Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
Jun 14 #Javascript
Vue动态创建注册component的实例代码
Jun 14 #Javascript
You might like
第十三节 对象串行化 [13]
2006/10/09 PHP
PHP中设置时区方法小结
2012/06/03 PHP
PHPMailer使用教程(PHPMailer发送邮件实例分析)
2012/12/06 PHP
PHP基于GD库的图像处理方法小结
2016/09/27 PHP
简单解决微信文章图片防盗链问题
2016/12/17 PHP
jquery获取ASP.NET服务器端控件dropdownlist和radiobuttonlist生成客户端HTML标签后的value和text值
2010/06/28 Javascript
主页面中的两个iframe实现鼠标拖动改变其大小
2013/04/16 Javascript
jquery更换文章内容与改变字体大小代码
2013/09/30 Javascript
javascript电商网站抢购倒计时效果实现
2015/11/19 Javascript
关于cookie的初识和运用(js和jq)
2016/04/07 Javascript
BootStrap智能表单实战系列(四)表单布局介绍
2016/06/13 Javascript
微信小程序 富文本转文本实例详解
2016/10/24 Javascript
详解在Angular项目中添加插件ng-bootstrap
2017/07/04 Javascript
详解React中的组件通信问题
2017/07/31 Javascript
JS实现根据指定值删除数组中的元素操作示例
2018/08/02 Javascript
vue生命周期和react生命周期对比【推荐】
2018/09/19 Javascript
基于游标的分页接口实现代码示例
2018/11/12 Javascript
js中对象与对象创建方法的各种方法
2019/02/27 Javascript
Vue 理解之白话 getter/setter详解
2019/04/16 Javascript
js实现简单掷骰子效果
2019/10/24 Javascript
JS合并两个数组的3种方法详解
2019/10/24 Javascript
vue项目中微信登录的实现操作
2020/09/08 Javascript
[02:54]DOTA2英雄基础教程 撼地者
2014/01/14 DOTA
[59:36]2018DOTA2亚洲邀请赛 4.3 突围赛 Secret vs VG 第二场
2018/04/04 DOTA
利用Django内置的认证视图实现用户密码重置功能详解
2017/11/24 Python
在Django中输出matplotlib生成的图片方法
2018/05/24 Python
python numpy 按行归一化的实例
2019/01/21 Python
Python内建序列通用操作6种实现方法
2020/03/26 Python
将keras的h5模型转换为tensorflow的pb模型操作
2020/05/25 Python
pytorch SENet实现案例
2020/06/24 Python
美国女性运动零售品牌:Lady Foot Locker
2017/05/12 全球购物
法国购买隐形眼镜和眼镜网站:Optical Center
2019/10/08 全球购物
优秀员工个人的自我评价
2013/11/29 职场文书
高中生学习的自我评价
2013/12/14 职场文书
最美乡村医生事迹材料
2014/06/02 职场文书
离婚起诉状范本
2015/05/19 职场文书