JavaScript 中全局对象的比较:Window、Global、Self、globalThis

阅读时长 4 分钟读完

在 JavaScript 中,全局对象是非常重要的概念,因为它们可以在整个代码中使用。然而,JavaScript 中有几个全局对象,包括 Window、Global、Self 和 globalThis,这些对象都有不同的特点和用途。在本文中,我们将详细讨论这些对象的比较。

Window 对象

Window 对象是最常见的全局对象之一,它代表浏览器窗口或框架。在浏览器中,Window 对象是全局对象,它包含了所有浏览器窗口和框架的属性和方法。它也是 DOM 的根节点,可以通过 Window 对象访问和操作文档中的元素。

在浏览器中,可以使用 Window 对象来访问全局变量和函数。例如:

需要注意的是,Window 对象只存在于浏览器中,Node.js 环境下不支持 Window 对象。

Global 对象

Global 对象是在浏览器中由 Window 对象派生出来的一个对象。Global 对象是在 JavaScript 运行时环境中创建的,它包含了所有全局变量和函数。在浏览器中,Global 对象与 Window 对象是相同的,可以使用 Global 对象来访问全局变量和函数。在 Node.js 环境下,Global 对象是一个全局命名空间,它包含了所有全局变量和函数。

从 ES5 开始,可以使用严格模式来避免使用 Global 对象。在严格模式下,全局变量必须通过 var、let 或 const 关键字声明,否则会报错。

Self 对象

Self 对象是一个全局对象,它代表当前执行的上下文。在浏览器中,Self 对象与 Window 对象是相同的。在 Node.js 环境下,Self 对象是一个全局变量,它指向全局对象。

Self 对象主要用于在 Web Worker 中访问全局变量和函数。Web Worker 是一个在后台运行的 JavaScript 程序,它可以在独立的线程中运行,与主线程分离。在 Web Worker 中,没有 Window 对象,但可以使用 Self 对象来访问全局变量和函数。

需要注意的是,Self 对象只在支持 Web Worker 的浏览器中存在。

globalThis 对象

globalThis 是从 ES11 开始引入的一个全局对象,它代表全局环境下的 this 值。在浏览器中,globalThis 对象与 Window 对象是相同的。在 Node.js 环境下,globalThis 对象指向全局对象。

globalThis 对象主要用于在不同环境下访问全局变量和函数。由于不同环境下有不同的全局对象,因此可以使用 globalThis 对象来访问全局变量和函数,而不关心当前环境是什么。

需要注意的是,globalThis 对象只在较新的 JavaScript 引擎中存在,因此在使用时需要进行兼容性检查。

总结

在 JavaScript 中,全局对象是非常重要的概念,它们可以在整个代码中使用。Window、Global、Self 和 globalThis 是 JavaScript 中常见的全局对象,它们都有不同的特点和用途。在使用时需要注意它们的区别和兼容性,以便更好地编写 JavaScript 代码。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/65532a03d2f5e1655dcdb822

纠错
反馈