ES2020 中 Javascript 10 个你应该知道的新功能
作者 | xiaoT
链接 | https://juejin.im/post/6844904137277046797
好消息 - ES2020 新功能已经落地!这就意味着,现在对 ES2020 中 Javascript 的新增和改进要有一个完整的了解。让我们来看看都有哪些改变。
1、BigInt
BigInt,Javascript 中最期待的新功能终于落地。它允许开发者在 JS 中使用更大的整数进行数据处理。
之前,Javascript 中最大的整数是 pow(2, 53) - 1
。但是,BigInt 不受此限制。
然而,就如你在上面看到,你需要在数字后面添加一个 n
。这个 n
说明这是一个 BigInt,Javascript 引擎应该特殊处理(不管是 V8,还是其它引擎)。
因为传统的数字系统是 IEEE754(它不支持这种大数字),因此,这个改进并不会向后兼容。
2、动态引入
Javascript 的动态引入,允许你把 JS 文件作为一个模块动态的引入到你的应用中。这就像你使用 webpack 和 Babel 一样。
这个功能可以帮助你处理按需加载的代码,拆分代码,而且,并不需要 webpack 或者其它模块处理器。如果,你喜欢也可以在 if-else 块中加载代码。
在 if-else 块中引入一个模块,这样的好处是:不会污染全局命名空间。
3、 空值合并
空值合并可以真正的检查 nullish
值,而不是 falsely
值。你或许会问:nullish
和 falsely
之间有什么不同呢?
在 Javascript 中有很多值都是 falsely
。比如:空字符串、数字 0、undefined
、null
、 false
、NaN
等。
然而,很多情况下你只想检测一个变量是否为空值 -- undefined
或者 null
,就像变量可以是一个空字符串甚至是一个假值。
在这个示例中,你将会看到新的空值合并操作符:??
。
你可以清楚的看到 OR 操作符总是返回一个真值,但是,空值操作符返回一个非空值。
4、可选链
可选链语法允许你访问嵌套更深的对象属性,而不用担心属性是否存在。如果,存在很好。反之,会返回 undefined
。
它不仅仅可操作对象属性,也可以操作函数的调用或者数组。这样更加方便!以下是个演示:
5、Promise.allSettled
Promise.allSettled
方法接收一组 Promise,并且会返回所有的结果 - 而不管是 resolved 还是 rejected。
在之前,这是不可能的,尽管有些类似的实现比如:race
和 all
。它只会“运行所有的 promise - 而不关心它们的结果”。
6、String#matchAll
matchAll
是 String
原型链上的一个新增的方法,它可以关联正则表达式。它返回一个迭代器,一个接一个的返回所有匹配的组。我们来看一个演示:
7、 globalThis
如果,你写过那些可以运行在 Node、浏览器或者 web-workers 等跨平台的 JS 代码,你就会花费很多的时间去处理全局对象的问题。
这是因为不同平台全局对象也不同,浏览器中是 window
,Node 中是 global
,web workers 中是 self
。如果,还有更多的运行环境,这个对象也会有不同。
因此,你自己必要检查运行环境来决定使用正确是全局对象。
ES2020 给我们带来了 globalThis
对象,它始终会引用着全局对象,而不用关系代码在哪运行:
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(对于内联脚本来说)。
总结
我喜欢 Javascript 社区不断发展的一致性和速度。看看 Javascript 如何从一种经过十年的嘘声演变成如今这种最强大、最灵活和最通用的语言,真的很神奇。
你是否希望用一种全新的方式学习 Javascript 和其它的编程语言?我正在开发一个全新的开发者平台 ,现在可以试下!
ES2020 中功能哪个是你喜欢的呢?可以在留言区给我们留言。
- 剑指offer代码解析——面试题21包含min函数的栈
- 剑指offer代码解析——面试题19二叉树的镜像
- mysql高可用架构设计,处理高并发,大流量!
- 零基础入门深度学习 | 第三章:神经网络和反向传播算法
- 微信企业付款到个人钱包引发的坑之反思~!
- Intellij idea创建javaWeb以及Servlet简单实现
- 设计模式之代理模式之读写分离!!!
- Phantomjs+Nodejs+Mysql数据抓取(1.数据抓取)
- Phantomjs+Nodejs+Mysql数据抓取(2.抓取图片)
- 深入浅出Redis-redis底层数据结构(上)
- Linux下自动化监控内存、存储空间!
- 深入浅出Redis-redis底层数据结构(下)
- Spring-boot:快速搭建微框架服务
- Mysql重要参数说明
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Kotlin 创建接口或者抽象类的匿名对象实例
- kotlin Context使用详解
- Android-ViewModel和LiveData使用详解
- 详解Android开发录音和播放音频的步骤(动态获取权限)
- Android自定义带圆角的ImageView
- 关于Kotlin写界面时诸多控件的点击事件
- Android webview注入JS代码 修改网页内容操作
- Kotlin 使用高阶函数实现回调方式
- Android WebView通过动态的修改js去拦截post请求参数实例
- Android使用Kotlin实现多节点进度条
- Android中webView加载H5绑定cookie实例
- 解决Android webview设置cookie和cookie丢失的问题
- Android实现清除单个域名的cookie
- Android实现触发html页面的Button控件点击事件方式
- webview添加参数与修改请求头的user-agent实例