es6进修笔记-顶层对象_v1.0_byKL

es6进修笔记-顶层对象_v1.0

(虽然是笔记,然则基本是抄了一次ruan巨匠的文章了)

顶层对象

  • 顶层对象,在浏览器环境指的是window对象,在Node指的是global对象。

  • ES5当中,顶层对象的属性与全局变量是等价的。

  • ES6为了转变这一点:

    • var敕令和function敕令声明的全局变量,依旧是顶层对象的属性;

    • let敕令、const敕令、class敕令声明的全局变量,不属于顶层对象的属性

global对象

  • 浏览器内里,顶层对象是window,

  • 但 Node 和 Web Worker 没有window。

  • 浏览器和 Web Worker 内里,self也指向顶层对象

  • 然则Node没有self,Node 内里,顶层对象是global,但其他环境都不支撑。

统一段代码为了能够在种种环境,都能取到顶层对象,如今平常是运用this变量,然则有局限性(以下):

  • 全局环境中,this会返回顶层对象。然则,Node模块和ES6模块中,this返回的是当前模块。(所以在node敕令行下剖析es6代码,this指向并非全局对象)

  • 函数内里的this,假如函数不是作为对象的要领运转,而是纯真作为函数运转,this会指向顶层对象。然则,严厉形式下,这时候this会返回undefined。不管是严厉形式,照样一般形式,new Function('return this')(),总是会返回全局对象。

  • 假如浏览器用了CSP(Content Security Policy,内容平安政策),那末eval、new Function这些要领都能够没法运用。

// 要领一
(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');
};
  1. typeof process === 'object' && typeof require === 'function' && typeof global === 'object'假如为true,且不存在window对象时能够以为在node环境中,node的全局对象就是global等价于浏览器中的window对象。这个是node的定义,参考node官方

  2. self(window.self) 返回window的只读援用,即为一个顶层对象,所以typeof self !== 'undefined'时,能够以为在浏览器环境下猎取到了顶层对象的一个只读援用

  3. typeof global !== 'undefined'这个就是猎取的node环境下的顶层对象,视察这两个函数,其作用都是猎取顶层对象,平常来说js较多用到的处所是浏览器端(前端)和node端(背景),

参考segmentfault

到场垫片库来完成global对象

在言语规范的层面,引入global作为顶层对象。也就是说,在所有环境下,global都是存在的,都能够从它拿到顶层对象。

垫片库system.global模拟了这个提案,能够在所有环境拿到global。

// CommonJS的写法
require('system.global/shim')();

// ES6模块的写法
import shim from 'system.global/shim'; shim();
上面代码能够保证种种环境内里,global对象都是存在的。


// CommonJS的写法
var global = require('system.global')();

// ES6模块的写法
import getGlobal from 'system.global';
const global = getGlobal();
上面代码将顶层对象放入变量global。

参考援用:

  1. es6-顶层对象

  2. es实战2015

    原文作者:线上猛如虎
    原文地址: https://segmentfault.com/a/1190000008598695
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞