伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

ECMAScript 2020 新增功能速成

来源:本站原创 浏览:50次 时间:2023-07-09
ECMAScript 2020 新增功能速成

疯狂的技术宅 前端先锋

ECMAScript 2020 是我们最喜欢的编程语言的第 11 版,其中包含一些新功能。有些是小特性,但有些将会有可能永远改变我们编写 JavaScript 的方式。

Dynamic import()

ES2015 引入了 static import 语法。现在你可以从一个模块导出变量,然后将其导入另一个模块。

1// utils.js2export function splitName(name) {3  return name.split(" ");4}56// index.js7import { splitName } from "./utils";89console.log(splitName("John Snow"));

这种语法被称为静态语法,因为你无法在运行时动态导入模块(取决于某些条件)。请注意,这不一定是坏事:可以在编译时优化静态导入,并允许 Tree Shaking。

另一方面,如果合理地使用了动态导入,则可以通过按需加载依赖项来帮助减少分发包的大小。

新的 dynamic import 语法看起来像一个函数(但不是),它返回 promise,这也意味着可以将其与 async/await一起使用。

1// ...2const mod = figure.kind === "rectangle" ? "rectangle.js" : "circle.js";3const { calcSquare } = await import(mod);4console.log(calcSquare(figure));
空值合并

流行的用 short-circuting 设置默认值的方法有其缺陷。由于它实际上不是在检查空值,而是在检查是否为“假”(https://developer.mozilla.org/zh-cn/docs/Glossary/Falsy),因此它会以诸如 false 或 0(两者均被视为假)。

ES2020引入了一个新的运算符 ??,该运算符的工作原理与其类似,但仅在初始值为 null 或 undefined 时才赋值为右手。

这是一个简单的例子:

1const initialVal = 0;23// old way4const myVar = initialVal || 10; // => 1056// new way7const myVar = initialVal ?? 10; // => 0
可选链

新的 optional chaining 运算符用来在处理嵌套对象并检查可能的 undefineds 时使代码更短。

 1const user = { name: "John" }; 2 3// Fails with `Uncaught TypeError: Cannot read property 'city' of undefined` 4const city = user.address.city; 5 6// Works but verbose 7let city = "Not Set"; 8if (user.address !== undefined && user.address !== null) { 9  city = user.address.city;10}1112// Works and concise but requires a 3rd party library13const city = _.get(user, "address.city", "Not Set");1415// 

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net