了解 ECMAScript 2020 中的全局对象 globalThis

前言

在过去的 JavaScript 版本中,没有一个标准的方式来访问全局对象。不同的 JavaScript 环境可能有不同的全局对象,如浏览器环境中的 window 对象、node.js 环境中的 global 对象。这些全局对象的不一致性给一些移植性较强的代码带来了麻烦。为了解决这个问题,ECMAScript 2020 引入了一个标准的全局对象——globalThis

globalThis 是什么?

globalThis 是 JavaScript 中的一个全局对象,用于在不同的环境中标准化地访问全局对象。globalThis 在所有 JavaScript 环境中都是存在的,不同环境下的全局对象,只需要通过 globalThis 访问即可。

通常情况下,在浏览器环境下,globalThis 就是 window 对象。在 node.js 环境下,globalThis 就是 global 对象。在 web worker 中,globalThis 就是 worker 的全局对象 self。

globalThis 为我们提供了一种标准的方式来访问全局对象,简化了代码的编写和移植性的工作。

globalThis 常见用途

1. 全局命名空间

在 JavaScript 中,很多开发者使用全局变量来定义一些全局的命名空间,这样可以确保其它模块不会意外地修改全局变量。但是,在不同的 JavaScript 环境中,全局变量的名称是不一样的,因此需要根据环境来选择。使用 globalThis,可以这样定义一个全局命名空间:

-- ------- ---------------------- --- ------------ -
  ---------------------- - ---
-

这段代码将会在任何 JavaScript 环境中创建一个名为 "myNameSpace" 的全局命名空间。

2. 动态导入 ES 模块

在 ECMAScript 2020 之前,JavaScript 语言规范并没有提供一种动态导入 ES 模块的标准方式,因此不同环境下也有不同的实现。使用 globalThis,可以在任何 JavaScript 环境中动态导入 ES 模块:

----- -------- ----------------------- -
  ----- - -------- ------ - - ----- -----------------------------
  ------ -------
-

该函数将动态加载指定的 ES 模块,并返回该模块的默认导出。在 web worker 中,globalThis.import() 将会使用 worker 的全局对象 self,而在 Node.js 中,globalThis.import() 将会使用 global 对象。

3. 调用全局函数

在 JavaScript 中,有一些全局函数是在所有环境中都存在的,例如:parseInt、encodeURIComponent、decodeURIComponent 等等。在过去,如果要在不同的环境中调用这些函数,需要使用不同全局对象访问,但是现在可以使用 globalThis 统一调用:

----- ------ - ---------------------------
----- --- - ---------------------------------------------------------

如果全局函数不是在所有环境中都存在,则需要使用环境特定的全局对象访问。

总结

globalThis 是 ECMAScript 2020 引入的一个标准全局对象,用于在所有 JavaScript 环境中统一访问全局对象。使用 globalThis 可以简化代码的编写和移植性的工作,同时支持动态导入 ES 模块、调用全局函数、定义全局命名空间等常见使用场景。

示例代码

1. 定义全局命名空间

-- ------- ---------------------- --- ------------ -
  ---------------------- - ---
-

------------------------ - ---
-------------------------------------- -- --

2. 动态导入 ES 模块

----- -------- ----------------------- -
  ----- - -------- ------ - - ----- -----------------------------
  ------ -------
-

-------------------------------------------------------------- -- -
  ----------------------------
---

3. 调用全局函数

----- ------ - ---------------------------
----- --- - ---------------------------------------------------------

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6494eaa948841e989423862c


猜你喜欢

  • 如何对 Koa2 请求参数进行签名校验

    前言 Koa2 是一个轻量级的 Web 框架。在开发 Web 应用、API 服务时,我们常常需要对请求进行校验,特别是在数据传输中,需要对请求参数进行一些特殊处理,如签名校验。

    1 年前
  • 如何实现跨域访问 RESTful API

    如何实现跨域访问 RESTful API 在前端开发中,我们经常会需要通过 AJAX 调用 RESTful API 进行数据交互。但是由于浏览器的同源策略限制,我们无法直接在前端代码中跨域访问其它域下...

    1 年前
  • React Native 中使用 Modal 实现弹窗效果

    在 React Native 的开发中,我们经常需要使用弹窗效果来增强用户交互性和体验性。弹窗效果可以用 Modal 实现。本文将详细介绍如何在 React Native 中使用 Modal 实现弹窗...

    1 年前
  • SASS 中变量作用域的理解及应用

    SASS 是一种 CSS 预处理器,它提供了很多方便的功能,其中变量是最基本的。在使用 SASS 的过程中,我们需要了解变量的作用域,并掌握其应用方法。 变量作用域 在 SASS 中,变量的作用域分为...

    1 年前
  • Mongoose 和 GraphQL 的结合使用

    在前端技术中,Mongoose 是一个常用的 MongoDB 数据库的连接工具,而GraphQL是一种新型的 API 查询语言。在实际工作中,我们会经常遇到需要使用Mongoose和GraphQL结合...

    1 年前
  • GraphQL Server 的性能优化技术

    GraphQL 是一种旨在改善 API 开发人员生产效率的查询语言,其核心思想是让客户端决定需要什么数据,而不需要由服务器端决定。但是,在构建 GraphQL 服务器时,如何保证其性能和可伸缩性仍然是...

    1 年前
  • 性能优化必备技能:利用 Chrome DevTools 检测 JavaScript 性能

    在前端开发中,我们常常需要考虑网站性能,其中一个方面就是 JavaScript 的性能。在这方面,我们可以利用 Chrome DevTools 来检测 JavaScript 的性能问题,找到问题并优化...

    1 年前
  • Docker Compose 搭建多个服务

    Docker Compose 是用来定义和运行多个 Docker 容器的工具,通过一个 YAML 文件来配置需要运行的服务,在使用 Docker Compose 时,用户只需要在命令行中执行一个命令,...

    1 年前
  • Angular:使用 RxJS 进行 AJAX 调用

    在现代的 Web 应用程序开发中,与后端 API 进行数据交换非常常见。对于 Angular 开发人员来说,使用 RxJS 可以轻松地进行 AJAX 调用。本文将介绍如何使用 RxJS 操作符和 An...

    1 年前
  • Socket.io 如何实现消息持久化存储?

    前言 随着现代 Web 应用的发展,即时通讯成为了数据交互的重要组成部分。而 Socket.io 作为一种实时通讯框架,已经成为了前端领域的重要技术。对于即时通讯场景,消息的持久化存储显得尤为重要。

    1 年前
  • 如何利用 Custom Elements 实现响应式的 UI 设计

    在前端开发中,响应式的 UI 设计是一项重要的任务。而 Custom Elements 是一种由 Web Components 技术组成的能力,它利用原生的浏览器 API,使开发者可以自定义 HTML...

    1 年前
  • Kubernetes 中容器更新与回滚的策略选择

    前言 随着云原生应用的兴起,容器化的应用部署已经成为了最佳实践。而在容器化部署中,Kubernetes 作为开源的容器编排平台越来越受到人们的关注。在大型容器集群中,容器的更新与回滚策略都是至关重要的...

    1 年前
  • MongoDB 索引优化实战指南

    前言 在 MongoDB 中使用索引是提高查询效率的重要手段。但是,如果索引使用不当,反而会降低查询性能。因此,本文将介绍 MongoDB 索引优化的一些实战经验和技巧,帮助读者学习如何优化索引,提高...

    1 年前
  • 解决 ES9 的 Object.fromEntries() 在 IE 浏览器下无法运行的问题

    在前端开发中,我们经常使用各种 JavaScript 方法和函数来处理数据。ES9 中新增的 Object.fromEntries() 方法,可以将一个由键值对组成的数组转换为一个对象。

    1 年前
  • 如何在 ESLint 中使用 JSDoc 注释

    前端工程师在开发过程中面对的问题之一就是如何规范代码,保证代码的质量和可读性。ESLint 是一个流行的 JavaScript 语法检查工具,它可以帮助我们检测代码中存在的问题,并提供解决方案。

    1 年前
  • ECMAScript 2021 中的函数参数监控详解

    在 ECMAScript 2021 中,新增了一些有趣的功能。其中一个值得关注的功能是函数参数监控。这个功能可以让我们监视和调试函数的参数,以便更好地理解函数的执行和输出。

    1 年前
  • 如何在 Deno 模块中查找依赖项?

    Deno 是一个现代化的 JavaScript 和 TypeScript 运行时环境,使用它可以在浏览器之外运行 JavaScript 以及 TypeScript 应用程序。

    1 年前
  • 解决在 Webpack 编译环境下使用 Enzyme 出现的问题

    概述 在前端开发中,我们经常会使用 Webpack 这个模块打包工具,同时也会用到 Enzyme 这个 React 组件测试工具。但是,在使用 Enzyme 进行测试时,会出现一些问题,特别是在 We...

    1 年前
  • 使用 Mocha 和 Chai 进行 Vue.js 应用程序测试的最佳实践

    前言 在前端开发中,测试是非常重要的环节。随着 Vue.js 越来越受欢迎,Vue.js 应用程序测试也变得更加重要。在本文中,我们将介绍如何使用 Mocha 和 Chai 进行 Vue.js 应用程...

    1 年前
  • TypeScript 中开发常见的设计模式

    设计模式是在软件开发中经常用到的重要思想和方法。它们能够帮助开发者更加高效地解决问题,提高代码质量,降低维护成本。在 TypeScript 中,设计模式同样可以发挥重要作用。

    1 年前

相关推荐

    暂无文章