我的编程空间,编程开发者的网络收藏夹
学习永远不晚

es6如何获取顶层对象

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

es6如何获取顶层对象

本篇内容介绍了“es6如何获取顶层对象”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

es6获取顶层对象的方式:1、利用“typeof window !== 'undefined' ? window : (...) ? global : this”方法获取;2、利用“var getGlobal = function () {...throw new Error('unable to locate global object');};”方法获取。

本教程操作环境:windows10系统、ECMAScript 6.0版本、Dell G3电脑。

es6获取顶层对象的方式

ES6之前,顶层对象的属性和全局变量是等价的,但是在ES6,顶层对象和全局对象开始分离。

不分离的弊端

  • 无法在编译阶段就报出变量未声明的错误,只有运行时才知道。

  • 容易在不知不觉中创建全局变量

  • 顶层对象可随意读写

  • window对象有窗口的意思,指的浏览器的窗口对象。而顶层对象有实体意义是一个不合适的设计

改变方式

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

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

顶层对象

浏览器:window对象

Node:global对象

不统一的顶层对象

浏览器中 顶层对象是window,但是Node和Web Worker没有window。

浏览器和Web Worker中,self也指向顶层对象,但是Node没有self。

Node中,顶层对象是global,但其他环境不支持。

获取顶层对象

局限性

全局环境中,this返回顶层对象;

Node模块和ES6模块中,this返回当前模块

函数中的this

(1) 单纯作为函数运行,this返回顶层

(2) 严格模式下,返回undefined

new Function(‘return this’)();总是返回全局对象。

但是如果浏览器用了CSP,那么eval,new Function这些方法都可能无法使用

CSP:Content Security Policy,内容安全政策。它以白名单的机制对网站加载或执行的资源起作用,在网页中通过HTTP头信息或者meta元素定义。但是也造成了以下问题

  1. eval及相关函数被禁用。

  2. 内嵌的JavaScript代码将不会执行。

  3. 只能通过白名单来加载远程脚本。

获取顶层对象的方法

// 方法1
// 针对 浏览器中 顶层对象是window,但是Node和Web Worker没有window。
( 
	typeof window !== 'undefined' ? window : (
		typeof process === 'object' &&
		typeof require === 'function' &&
		typeof global === 'object'
	) ? global : this
);

//方法2
// 针对 浏览器和Web Worker中,self也指向顶层对象,但是Node没有self。
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');
};

“es6如何获取顶层对象”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

es6如何获取顶层对象

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java如何获取对象深层数据

要获取对象的深层数据,可以使用递归方法来遍历对象的属性。```javapublic class Main {public static void main(String[] args) {// 创建一个对象Person person = n
2023-09-15

iOS如何获取最顶层ViewController详解

1 获取当前屏幕显示的 Viewcontroller//获取当前屏幕显示的viewcontroller - (UIViewController *)getCurrentVC {///下文中有分析UIViewController *rootV
2022-05-21

java如何获取session对象

在Java中,可以通过以下方式获取session对象:1. 在JSP页面中:`HttpSession session = request.getSession();`2. 在Servlet中:`HttpSession session = r
2023-09-27

python如何获取对象信息

这篇文章主要讲解了“python如何获取对象信息”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python如何获取对象信息”吧!1、获取对象类型,基本类型可以用type()来判断。>>> t
2023-06-20

ES6对象如何使用

本篇内容介绍了“ES6对象如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、对象和属性和方法JavaScript中对象:var pe
2023-06-30

python如何获取对象的大小

这篇文章将为大家详细讲解有关python如何获取对象的大小,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。获取对象的大小内存大小根据对象的类型而变化。 我们可以使用sys模块中的getsizeof()函数获
2023-06-27

JavaScript如何获取对象的所有键

这篇文章主要为大家展示了“JavaScript如何获取对象的所有键”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript如何获取对象的所有键”这篇文章吧。获取对象的所有键cosnt
2023-06-27

js如何获取对象的属性名

要获取对象的属性名,可以使用`Object.keys()`方法。示例代码如下:```javascriptconst obj = {name: 'John',age: 30,gender: 'male'};const keys = Objec
2023-08-08

C#如何获取DataTable对象状态DataRowState

这篇文章将为大家详细讲解有关C#如何获取DataTable对象状态DataRowState,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。DataGridView:获取 DataRow 对象的状态,共有5个
2023-06-29

js如何获取json对象的key值

本篇内容主要讲解“js如何获取json对象的key值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js如何获取json对象的key值”吧!JavaScript 对象是由键值对创建的,也不像数组,
2023-06-26

ES6中如何使用Promise对象

这篇文章主要介绍了ES6中如何使用Promise对象的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇ES6中如何使用Promise对象文章都会有所收获,下面我们一起来看看吧。在promise之前处理异步回调的方式
2023-06-17

编程热搜

目录