摘要:学习笔记顶层对象虽然是笔记但是基本是抄了一次大师的文章了顶层对象顶层对象,在浏览器环境指的是对象,在指的是对象。之中,顶层对象的属性与全局变量是等价的。的写法模块的写法上面代码将顶层对象放入变量。参考引用顶层对象实战
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"); };
typeof process === "object" && typeof require === "function" && typeof global === "object"如果为true,且不存在window对象时可以认为在node环境中,node的全局对象就是global等价于浏览器中的window对象。这个是node的定义,参考node官方
self(window.self) 返回window的只读引用,即为一个顶层对象,所以typeof self !== "undefined"时,可以认为在浏览器环境下获取到了顶层对象的一个只读引用
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。
参考引用:
es6-顶层对象
es实战2015
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/86802.html
摘要:考虑到环境导致的行为差异太大,应该避免在块级作用域内声明函数。函数声明语句函数表达式循环循环还有一个特别之处,就是循环语句部分是一个父作用域,而循环体内部是一个单独的子作用域。声明一个只读的常量。 es6学习笔记-let,const和块级作用域_v1.0 块级作用域 javascript 原来是没有块级作用域的,只有全局作用域和函数作用域 例子1 因为没有块级作用域,所以每次的i都是一...
摘要:因为箭头函数本身没有所以不可以当作构造函数,也就是说,不可以使用命令,否则会抛出一个错误。箭头函数不可以使用对象,该对象在函数体内不存在。 es6学习笔记-箭头函数_v1.0 箭头函数使用方法 var f = v => v; //普通函数配合箭头函数写法,这里并且是传参的 //相当于 var f = function(v) { return v; }; /*-----------...
摘要:学习笔记数值的扩展有一些不常用或者还不支持的就没有记录了总体来说本篇只是一个备忘而已用来检查一个数值是否为有限的。两个新方法只对数值有效,非数值一律返回。参考引用数值扩展 es6学习笔记-数值的扩展 有一些不常用或者还不支持的就没有记录了,总体来说本篇只是一个备忘而已 Number.isFinite(), Number.isNaN() Number.isFinite()用来检查一个数值...
摘要:学习笔记函数扩展函数参数的默认值如果参数默认值是变量,那么参数就不是传值的,而是每次都重新计算默认值表达式的值。属性函数的属性,返回该函数的函数名。箭头函数详细链接参考引用函数扩展 es6学习笔记-函数扩展_v1.0 函数参数的默认值 function Point(x = 0, y = 0) { this.x = x; this.y = y; } var p = ne...
摘要:学习笔记字符串的扩展字符的表示法允许使用的形式表示一个字符,但在之前,单个码点仅支持到,超出该范围的必须用双字节形式表示,否则会解析错误。返回布尔值,表示参数字符串是否在源字符串的头部。,是引入了字符串补全长度的功能。 es6学习笔记-字符串的扩展_v1.0 字符的Unicode表示法 JavaScript 允许使用uxxxx的形式表示一个字符,但在 ES6 之前,单个码点仅支持u00...
阅读 3069·2023-04-25 16:50
阅读 903·2021-11-25 09:43
阅读 3512·2021-09-26 10:11
阅读 2517·2019-08-26 13:28
阅读 2530·2019-08-26 13:23
阅读 2418·2019-08-26 11:53
阅读 3566·2019-08-23 18:19
阅读 2987·2019-08-23 16:27