写点什么

“学不动了!”系列之 ES2021 抢先尝

  • 2021-07-31
  • 本文字数:2548 字

    阅读完需:约 8 分钟

“学不动了!”系列之 ES2021 抢先尝

从 ES2015(ES6)之后,每年,JS 都会在其新标准里添加一些有意思的新特性。


我们可以看一下已经进入 Stage 4 阶段的提案,这些提案到时候都会进入 ES2021 的标准。


(Stage 4 是啥?)TC39 在把提案转换为最后的标准之前,这些提案都会经历 State 1~4 四个阶段。只有到 Stage 4 的提案会被标记为“已完成”,并在将来进入到下一个 ES 标准里。有兴趣的话,可以点击这里查看目前每个 Stage 都有哪些提案。


特性一览

String.prototype.replaceAll


大家应该都使用过 String.prototype.replace 来替换字符串中的某些匹配给定正则表达式的部分。但是,如果我们所使用的匹配规则不是一个正则表达式,而是一个普通的字符串,只有 第一个 匹配的才会被替换。


const str = 'I like frontend. I like JavaScript.';const newStr = str.replace('like', 'love');newStr;// "I love frontend. I like JavaScript."
复制代码


如果你需要替换所有的 "like",那我们只能用正则表达式 /like/g 来进行匹配。有

了 String.prototype.replaceAll 这个 API,我们就可以轻松替换掉所有的字符串啦。


const str = 'I like frontend. I like JavaScript.';const newStr = str.replaceAll('like', 'love');newStr;// "I love frontend. I love JavaScript."
复制代码


其实这个 API 在一些浏览器的最新版本已经得到了实现,只是还未进入标准。比如在 Edge、Opera 或者 Node.js 中我们就暂时无法使用这个 API。


Promise.any


Promise 在过去的几年里,已经更新过了若干的新的 API。除了 ES6 的 Promise.allPromise.race 之外,还有去年发布的 ES2020 中的 Promise.allSettled。现在,我们来看一个新的 API:Promise.any。从字面意思来看,相信聪明的你应该能大致猜出这个 API 的作用。


与 Promise.all 类似,Promise.any 也接受一个 Promise 的数组。当其中任何一个 Promise 完成(fullfill)时,就返回那个已经有完成值的 Promise。如果所有的 Promise 都拒绝(reject),则返回一个拒绝的 Promise,该 Promise 的返回值是一个 AggregateError 对象。我们可以把 Promise.any 理解成 Promise.all 的相反操作。


Promise.any(promises).then(  (first) => {    // 任何一个 Promise 完成了  },  (error) => {    // 所有的 Promise 都拒绝了  });
复制代码


逻辑赋值操作符


我们知道,下面的代码:


let a = 0;a = a + 2;
复制代码


可以简写为:


let a = 0;a += 2;
复制代码


那么这个新的标准中,逻辑表达式的操作符(&&||??)也可以简写啦。(关于 ES2020 标准的 ?? 操作符,后文会稍微补充一下)。我们看一下示例代码:


// 等同于 a = a || ba ||= b;// 等同于 c = c && dc &&= d;// 等同于 e = e ?? f// 咦,?? 这是啥e ??= f;
复制代码


在这里,补充一下去年发布的标准中的新的逻辑操作符 ?? 的用法。大家可能遇到过,如果一个变量是空,需要给它赋值为一个默认值的情况。新手同学可能会这么写:


let count = realCount || '无法获取'
复制代码


但是,以上的代码会有一个 bug。如果 realCount 的值是 0,则会被当作取不到其值,会取到 '无法获取' 这个字符串。而如果我们使用了 ??,只有当操作符左边的值是 null 或者 undefined 的时候,才会取操作符右边的值:

let count = realCount ?? '无法获取'
复制代码

数字分隔符


如果你要写一个很长的数字的时候:


let x = 233333333
复制代码


数字太长会导致可读性很差。使用了数字分隔符 _ (下划线),就可以让数字读的更清晰:


let x = 2_3333_3333// x 的值等同于 233333333,只是这样可读性更强,不用一位一位数了
复制代码


WeakRef


WeakRef 是一个 Class,一个 WeakRef 对象可以让你拿到一个对象的弱引用。这样,就可以不用阻止垃圾回收这个对象了。我们可以使用其构造函数来创建一个 WeakRef 对象


// someObj 不会因为 ref 引用了这个对象,而不会被垃圾回收let ref = new WeakRef(someObj);
复制代码


那我们在使用上述代码中的 someObj 对象时,就可以用 WeakRef.prototype.deref() 来取道。但是,在被引用对象被垃圾回收之后,这个函数就会返回 undefined


// 如果 someObj 被垃圾回收了,则 obj 就会是 undefinedlet obj = ref.deref();
复制代码

Intl.ListFormat


Intl.ListFormat 是一个构造函数,用来处理和多语言相关的对象格式化操作。来通过一个例子了解一下。


const list = ['Apple', 'Orange', 'Banana']new Intl.ListFormat('en-GB', { style: 'long', type: 'conjunction' }).format(list);// "Apple, Orange and Banana"new Intl.ListFormat('zh-cn', { style: 'short', type: 'conjunction' }).format(list);// 会根据语言来返回相应的格式化操作// "Apple、Orange和Banana"
复制代码


这个 API 支持多国语言,具体的 API 可以参考 这里。


Intl.DateTimeFormat API 中的 dateStyle 和 timeStyle 的配置项


Intl.DateTimeFormat 是一个用来处理多语言下的时间日期格式化的函数。ES2021 中给这个函数添加了两个新的参数:dateStyle 和 timeStyle。下面我们来通过例子来看一下这两个参数的用法:


let o = new Intl.DateTimeFormat("en" , {  timeStyle: "short"});console.log(o.format(Date.now())); // "13:31"let o = new Intl.DateTimeFormat("en" , {  dateStyle: "short"});console.log(o.format(Date.now())); // "21.03.2012"// 可以通过同时传入 timeStyle 和 dateStyle 这两个参数来获取更完整的格式化时间的字符串let o = new Intl.DateTimeFormat("en" , {  timeStyle: "medium",  dateStyle: "short"});console.log(o.format(Date.now())); // "21.03.2012, 13:31"
复制代码


读完是不是心动了?这些 API 在最新版的 Chrome 都已经得到了支持,赶紧尝尝鲜吧。如果要在生产环境中使用,记得处理兼容性问题哦。



头图:Unsplash

作者:陈宇清

原文:https://mp.weixin.qq.com/s/O78fK2Yh_XQE1y23QSQxRg

原文:“学不动了!”系列之 ES2021 抢先尝

来源:微医大前端技术 - 微信公众号 [ID:wed_fed]

转载:著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

2021-07-31 07:002048

评论

发布
暂无评论
发现更多内容

Wallys//AX200NGW,adapter card with one M.2 slot/DR2g41 Linux,WiFi-modules,4-miniPCIE-slot

wallysSK

AX200NGW

推荐8个提高工作效率的IntelliJ插件

JAVA旭阳

Java IDEA

无效回表谁的锅?存储引擎:这事儿不赖我

小小怪下士

Java MySQL 程序员

港华燃气上线WeOps推动运维效能提升,托举业务智慧运行!

嘉为蓝鲸

运维 自动化运维 嘉为蓝鲸 #WeOps

跨平台应用开发进阶(三十一) :uni-app实现覆盖原生控件导航栏和tabbar全屏弹窗

No Silver Bullet

uni-app 跨平台应用 12月月更 原生控件覆盖 全屏弹窗

小游戏未来将在技术侧如何发展

Onegun

小游戏 小游戏开发

ArkUI,更高效的框架设计

HarmonyOS开发者

HarmonyOS

直播预约|阿里云EMR 2.0 重磅发布

阿里云大数据AI技术

大数据 阿里云 大数据 开源

HarmonyOS 3优化游戏续航,nova 6等老机型升级后游戏续航更持久

极客天地

汽车行业:充分借力数据价值,推动数字化营销链路闭环

HarmonyOS SDK

HMS Core

如何使用轮播图在小程序内实现水平内容自动切换?

Towify

小程序 微信小程序 无代码 轮播图

可观测落地实践-从战略管理到工具落地

嘉为蓝鲸

可观测 自动化运维 嘉为蓝鲸

嘉为蓝鲸受邀出席汽车新智造数字行业峰会,助力构建数字时代竞争力!

嘉为蓝鲸

数字时代 自动化运维 嘉为蓝鲸

什么是 Redis 持久化,如何理解?

千锋IT教育

Redis 6.0

跨平台应用开发进阶(三十):uni-app 实现集成火山视频直播服务

No Silver Bullet

uni-app 12月月更 服务集成 火山视频直播服务

如何用3D流体实现逼真水流效果?

HarmonyOS SDK

HMS Core

什么是低代码?低代码平台能解决什么样的问题?

优秀

低代码 低代码平台

教你如何轻松搞定云上打印管理

华为云开发者联盟

云计算 华为云 12 月 PK 榜 云打印

跨平台应用开发进阶(三十二) :AK/SK鉴权原理简介

No Silver Bullet

uni-app 12月月更 AK/SK鉴权

Dubbo架构设计与源码解析(二) 服务注册

京东科技开发者

架构 dubbo spi 服务注册 Dubbo SPI

如何制作一个实时在线显示评论?

Towify

微信小程序 编辑器 无代码

数据库原理及MySQL应用 | 实体联系模型

TiAmo

数据库 :MySQL 数据库 12月月更

【开源项目】今天推荐一个很好的开源项目,一款新的编程语言——HVML

hvmlenvoy

GitHub 编程语言 开源项目

云原生时代的灰度发布有几种“姿势”?

嘉为蓝鲸

灰度发布 自动化运维 嘉为蓝鲸

手把手教你成为荣耀开发者:如何获取平台帮助及最新通知?

荣耀开发者服务平台

开发者 安卓 平台赋能 数智创新 honor 技术支持

双旦来临,贾斯特里尼&布鲁克斯红酒为您多添一份情调

联营汇聚

Gradle基础操作一

派大星

Gradle

YonBuilder移动开发平台AVM框架封装数据表格组件

YonBuilder低代码开发平台

开发者 前端 AVM

YonBuilder移动开发平台 AVM框架 数字滚动组件

YonBuilder低代码开发平台

开发者 前端 avm.js AVM

本年度软件供应链攻击事件回顾

SEAL安全

基础设施 第三方风险 软件供应链安全 软件供应链攻击 12 月 PK 榜

“学不动了!”系列之 ES2021 抢先尝_语言 & 开发_微医大前端技术_InfoQ精选文章