js的global 对象

正文开始

<p>www.gruntjs.net/getting-started</p><p><br /></p><p>ES5 的顶层对象,本身也是一个问题,因为它在各种实现里面是不统一的。</p>浏览器里面,顶层对象是window,但 Node 和 Web Worker 没有window。浏览器和 Web Worker 里面,self也指向顶层对象,但是 Node 没有self。Node 里面,顶层对象是global,但其他环境都不支持。<p>同一段代码为了能够在各种环境,都能取到顶层对象,现在一般是使用this变量,但是有局限性。</p>全局环境中,this会返回顶层对象。但是,Node 模块和 ES6 模块中,this返回的是当前模块。函数里面的this,如果函数不是作为对象的方法运行,而是单纯作为函数运行,this会指向顶层对象。但是,严格模式下,这时this会返回undefined。不管是严格模式,还是普通模式,new Function('return this')(),总是会返回全局对象。但是,如果浏览器用了 CSP(Content Security Policy,内容安全政策),那么eval、new Function这些方法都可能无法使用。<p>综上所述,很难找到一种方法,可以在所有情况下,都取到顶层对象。下面是两种勉强可以使用的方法。</p><pre>// 方法一 (typeof window !== 'undefined' ? window : (typeof process === 'object' && typeof require === 'function' && typeof global === 'object') ? global : this); // 方法二 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'); }; </pre><p>现在有一个<a href="https://github.com/tc39/proposal-global">提案</a>,在语言标准的层面,引入global作为顶层对象。也就是说,在所有环境下,global都是存在的,都可以从它拿到顶层对象。</p><p>垫片库<a href="https://github.com/ljharb/System.global">system.global</a>模拟了这个提案,可以在所有环境拿到global。</p><pre>// CommonJS 的写法 require('system.global/shim')(); // ES6 模块的写法 import shim from 'system.global/shim'; shim(); </pre><p>上面代码可以保证各种环境里面,global对象都是存在的。</p><pre>// CommonJS 的写法 var global = require('system.global')(); // ES6 模块的写法 import getGlobal from 'system.global'; const global = getGlobal(); </pre><p>上面代码将顶层对象放入变量global。</p>

正文结束

js 正则替换返回值做回调函数 在各种JavaScript运行环境中取得全局对象global的方法