在 JavaScript 的开发中,我们经常需要访问全局对象,比如 window 对象在浏览器环境中,或者 global 对象在 Node.js 环境中。然而,在不同的环境下,访问全局对象的方式会有所不同,这给跨平台的开发带来了一定的困难。ES11 中引入了一个新的全局标记 globalThis,解决了这个问题。
globalThis 的基本用法
globalThis 是 ES11 新增的一个全局对象,表示当前环境下的全局对象。无论在哪个环境下,我们都可以通过 globalThis 来访问全局对象。例如,在浏览器和 Node.js 中,可以像下面这样使用:
// 在浏览器中 console.log(globalThis); // 输出 window 对象 // 在 Node.js 中 console.log(globalThis); // 输出 global 对象
globalThis 的优势
globalThis 的优势在于不再需要根据不同的环境来判断使用哪个对象来表示全局对象。在一些特殊的场景下,这种方式可以带来显著的优势。例如,我们可以通过在一个 iframe 内嵌入脚本的方式,实现一个网站调用另一个网站的接口。在这个场景下,我们想要执行的全局函数可能是在父窗口中定义的,也可能是在子窗口中定义的。使用 globalThis 可以保证我们的代码可以正确地访问到全局函数。
-- -------------------- ---- ------- ---- ---------- --- --------- ----- ------ ------ ------------- -------------- ------- ------ ------- -------------------------- -------- -------- ------------- - ------------------ ---- ------ --------- - -- -------- -------- -------------------- - ----- ------ - --------------------------------- ---------------------------------- ----- ------- -- ----- - -- -------- ---------------------------------- ----- -- - -- ---------------- --- -------- - ------------------------- - --- --------- ------- -------展开代码
-- -------------------- ---- ------- ---- ---------- --- --------- ----- ------ ------ ------------ -------------- ------- ------ ------- ----------------------------- ----------- -------- -------- ------------- - ------------------ ---- ----- --------- - -- -------- -------- --------------------- - --------------------------- ----- ------- -- ----- - --------- ------- -------展开代码
使用 globalThis 兼容历史代码
在历史代码中,我们经常使用类似 window 或 global 这样的对象来表示全局对象。但是,随着 globalThis 的出现,使用 globalThis 可以更加方便地兼容历史代码。例如,在以前的代码中,我们可能会这样写:
if (typeof window !== 'undefined') { // 在浏览器环境中执行代码 window.alert('Hello World'); } else if (typeof global !== 'undefined') { // 在 Node.js 环境中执行代码 global.console.log('Hello World'); }
使用 globalThis 可以将这段代码简化为:
globalThis.alert('Hello World'); globalThis.console.log('Hello World');
结论
ES11 中新增的 globalThis 对象可以让开发者在不同的环境下,方便地访问全局对象。使用 globalThis 的优势在于不再需要根据不同的环境来判断使用哪个对象来表示全局对象,从而兼容历史代码并且提升开发效率。因此,在开发过程中,我们应该正确地使用 globalThis,从而充分利用它的优势。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/67241d922e7021665e125fd9