当前位置: 首页 > 编程笔记 >

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

钱锦
2023-03-14
本文向大家介绍ES6顶层对象、global对象实例分析,包括了ES6顶层对象、global对象实例分析的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了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程序设计有所帮助。

 类似资料:
  • 本文向大家介绍ES6对象操作实例详解,包括了ES6对象操作实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了ES6对象操作。分享给大家供大家参考,具体如下:  1.对象赋值 es5中的对象赋值方式如下: 结果为: ES6允许把声明的变量直接赋值给对象,例如: 结果与上述相同。 2.对象Key值构建 有时候我们会在后台取出key值,而不是我们前台定义好的,这时候我们可以我们可以把后台定

  • 主要内容:1.ES6对象文字语法扩展,2.合并ES6中的对象,3.对象解构对象是键/值对的集合,可以像哈希或字典一样在对象的整个生命周期中对其进行修改。在JavaScript中使用对象可以定义自定义数据类型。 与原始数据类型不同,使用对象表示复杂或多个值。 这些值可以是对象数组或标量值,也可以是函数。对象内部的数据是无序的,值可以是任何类型。 可以使用大括号以及可选的属性列表来创建对象。 该属性是“键:值”对,其中键是字符串或属性名称,值可以是任何值。 语法 创建空对象

  • 本文向大家介绍JavaScript内置对象math,global功能与用法实例分析,包括了JavaScript内置对象math,global功能与用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript内置对象math,global功能与用法。分享给大家供大家参考,具体如下: 学习要点: 1.Global对象 2.Math对象 ECMA-262对内置对象的定义是:“

  • Node.js全局对象本质上是全局的,并且它们在所有模块中都可用。 我们不需要在我们的应用程序中包含这些对象,而是可以直接使用它们。 这些对象是模块,函数,字符串和对象本身,如下所述。 __filename __filename表示正在执行的代码的文件名。 这是此代码文件的已解析绝对路径。 对于主程序,这不一定与命令行中使用的文件名相同。 模块内部的值是该模块文件的路径。 例子 (Example)

  • 主要内容:1.Boolean属性,2.Boolean方法ES6 Boolean对象可以表示两个值,即或。 在JavaScript中,布尔值用作获取对象,变量,条件,表达式等值的函数,它们包括和。 如果省略参数或,负数,,,,或空()字符串,则对象具有初始值。 语法 对象有三种方法和两个属性。下面来详细的了解对象的属性和方法。 1.Boolean属性 布尔对象的两个属性列表如下: 序号 属性 说明 1. 此属性返回对象的构造函数。 2. 用于将属性和方法

  • 主要内容:1.Number属性,2.Number方法,3.二进制,八进制和十六进制文字ES6 Number对象具有执行日期,浮点数,整数等数字功能的几种方法和属性。使用ES6中可以使用对象来实现数字的操作。 这是因为浏览器会自动将数字文字转换为类的实例。 使用构造函数创建对象。 对象的一些主要用途包括,当参数无法转换为数字时将返回:。 语法 参数说明: :这是要创建的对象的数值。如果提供非数字参数,则它将返回,因为相应的参数无法转换为数字。 1.Number属性 下面来看看ES6中