首页 > 其他分享 >【ES】757- 10个 ES2020 新功能

【ES】757- 10个 ES2020 新功能

时间:2022-10-21 23:31:46浏览次数:107  
标签:10 757 ES2020 Javascript 空值 meta 模块 import utils

【ES】757- 10个 ES2020 新功能_javascript

译者:xiaoT

​https://www.freecodecamp.org/news/javascript-new-features-es2020​

好消息 - ES2020 新功能已经落地!这就意味着,现在对 ES2020 中 Javascript 的新增和改进要有一个完整的了解。让我们来看看都有哪些改变。

1: BigInt

BigInt,Javascript 中最期待的新功能终于落地。它允许开发者在 JS 中使用更大的整数进行数据处理。

之前,Javascript 中最大的整数是 ​​pow(2, 53) \- 1​​。但是,BigInt 不受此限制。

【ES】757- 10个 ES2020 新功能_javascript_02

然而,就如你在上面看到,你需要在数字后面添加一个 ​​n​​​。这个 ​​n​​ 说明这是一个 BigInt,Javascript 引擎应该特殊处理(不管是 V8,还是其它引擎)。

因为传统的数字系统是 IEEE754(它不支持这种大数字),因此,这个改进并不会向后兼容。

2:动态引入

Javascript 的动态引入,允许你把 JS 文件作为一个模块动态的引入到你的应用中。这就像你使用 webpack 和 Babel 一样。

这个功能可以帮助你处理按需加载的代码,拆分代码,而且,并不需要 webpack 或者其它模块处理器。如果,你喜欢也可以在 if-else 块中加载代码。

在 if-else 块中引入一个模块,这样的好处是:不会污染全局命名空间。

【ES】757- 10个 ES2020 新功能_javascript_03

3: 空值合并

空值合并可以真正的检查 ​​nullish​​​ 值,而不是 ​​falsely​​​ 值。你或许会问:​​nullish​​​ 和 ​​falsely​​ 之间有什么不同呢?

在 Javascript 中有很多值都是 ​​falsely​​​。比如:空字符串、数字 0、​​undefined​​​ 、​​null​​​、 ​​false​​​ 、​​NaN​​ 等。

然而,很多情况下你只想检测一个变量是否为空值 -- ​​undefined​​​ 或者 ​​null​​,就像变量可以是一个空字符串甚至是一个假值。

在这个示例中,你将会看到新的空值合并操作符:​​??​​。

【ES】757- 10个 ES2020 新功能_javascript_04

你可以清楚的看到 OR 操作符总是返回一个真值,但是,空值操作符返回一个非空值。

4:可选链

可选链语法允许你访问嵌套更深的对象属性,而不用担心属性是否存在。如果,存在很好。反之,会返回 ​​undefined​​。

它不仅仅可操作对象属性,也可以操作函数的调用或者数组。这样更加方便!以下是个演示:

【ES】757- 10个 ES2020 新功能_全局对象_05

5: Promise.allSettled

​Promise.allSettled​​ 方法接收一组 Promise,并且会返回所有的结果 - 而不管是 resolved 还是 rejected。

在之前,这是不可能的,尽管有些类似的实现比如:​​race​​​ 和 ​​all​​。它只会“运行所有的 promise - 而不关心它们的结果”。

【ES】757- 10个 ES2020 新功能_javascript_06

6: String#matchAll

​matchAll​​​ 是 ​​String​​ 原型链上的一个新增的方法,它可以关联正则表达式。它返回一个迭代器,一个接一个的返回所有匹配的组。我们来看一个演示:

【ES】757- 10个 ES2020 新功能_操作符_07

7: globalThis

如果,你写过那些可以运行在 Node、浏览器或者 web-workers 等跨平台的 JS 代码,你就会花费很多的时间去处理全局对象的问题。

这是因为不同平台全局对象也不同,浏览器中是 ​​window​​​,Node 中是 ​​global​​​,web workers 中是 ​​self​​。如果,还有更多的运行环境,这个对象也会有不同。

因此,你自己必要检查运行环境来决定使用正确是全局对象。

ES2020 给我们带来了 ​​globalThis​​ 对象,它始终会引用着全局对象,而不用关系代码在哪运行:

【ES】757- 10个 ES2020 新功能_javascript_08

8:导出模块的命名空间

Javascript 模块中,一直都可以使用以下这种语法:

import * as utils from './utils.mjs'

然而,直到现在还不可以像以下这样使用 ​​export​​ 语法:

译者注:目前是支持的(2020-04-24)

export * as utils from './utils.mjs'

以上和以下结果相同:

import * as utils from './utils.mjs'
export { utils }

9:明确定义 for-in 的顺序

ECMA 规范中并没有明确定义 ​​for (x in y)​​ 的顺序。尽管,在此之前浏览器实现了一致的顺序,但是,现在已经被纳入到 ES2020 的官方规范中了。

10: import.meta

​import.meta​​​ 是由 ECMAScript 创建实现的,默认为 ​​null​​。

考虑一下这个模块,​​module.js​​ :

<script type="module" src="module.js"></script>

你可以通过 ​​import.meta​​ 对象访问模块的相关 meta 信息:

console.log(import.meta); // { url: "file:///home/user/module.js" }

它返回一个包含 ​​url​​ 属性的对象,该属性代表着模块的 URL。它可能是获取脚本的 URL(对于外部脚本来说),或者是包含模块文档的基础URL(对于内联脚本来说)。


【ES】757- 10个 ES2020 新功能_javascript_09


标签:10,757,ES2020,Javascript,空值,meta,模块,import,utils
From: https://blog.51cto.com/u_11887782/5784666

相关文章

  • 2022.10.21-代码大全-10月读后感2
    近期,我阅读了这本书的软件构造为何如此重要这一部分。我了解到了提高软件的质量和开发者的生产效率都是十分重要的。一些常见的项目,都从软件开发实践的改进中收益。我了解......
  • 牛客练习赛104 D 逃亡的贝贝
    https://ac.nowcoder.com/acm/contest/43058/D思路二分答案,对于超过当前答案并且操作后可以使用的边边权当做1,短边当做0,跑一遍最短路,非常经典的二分题代码#include<alg......
  • 牛客练习赛104 C 1919810
    https://ac.nowcoder.com/acm/contest/43058/C思路一个很简单的dp记录每一位i可以给下一位的j提供的方案数理论上层数应该倒着枚举,但是我这个写法恰好避免了重复,所以正......
  • 牛客练习赛104 B 114514
    https://ac.nowcoder.com/acm/contest/43058/B思路要求1~n满足如下式子的个数\((i^{11}-i)(i^{451}-i^4)\equiv(i^{11}-i^4)(i^{11}-i)(mod451*4)\)打表可知,全都符合......
  • 【闲话】2022.10.21
    今天搬到了宾馆进行隔离!开始了快乐的集训生活!欢迎线下面基在路上打了两把雀食(真好玩然后推了一把虹龙洞好家伙三面疮了4次我好菜啊(笑接下来几天可能得到了外网加......
  • P2604 [ZJOI2010]网络扩容 | 建平行边
    本来的思路是纯纯地打一个大暴力在残余网络上跑spfa,每跑出一条增广路就是当前能扩容的最小花费然后k<=10,只需要跑最多十次:)正解是建平行边啦,容量为inf,费用为扩容费用,......
  • CF1045G 题解
    前言题目传送门!更好的阅读体验?和模版稍有不同的cdq分治。思路cdq是离线算法,所以我们可以先给\(x_i\)离散化一下。同时,记录下\((x_i-r_i)\)与\((x_i+r_i)......
  • windows10更新后任务栏卡死解决办法
    解决办法1:卸载windows更新,这个方法我在上次就是这么搞得,但是这次我进去卸载更新里没有时间,我选择了方法2,参考:https://jingyan.baidu.com/article/ea24bc39ea20ac9b62b3319......
  • 江南信息学第七周练习20221021
    比赛链接  6436计算表达式的值 6656bth的年龄问题 6989比赛准备 7190猜数游戏1 7623粗心的小L2.0 7501因子个数1 7560数字和 7585兔子繁......
  • 输入10个整数,输出最大值、最小值和平均值。
    要求:10个数需要从键盘输入,平均值保留两位小数。​程序代码#define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>floatMax(floatx,floaty){     if(x>y)   ......