精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

不容錯過!ES2020的七大新特性

原創
開發 前端
ES2020 是 ECMAScript 對應 2020 年的版本。這個版本不像 ES6 (ES2015)那樣包含大量新特性。但也添加了許多有趣且有用的特性。本文以簡單的代碼示例來介紹 ES2020新特性。

【51CTO.com原創稿件】前言

ES2020 是 ECMAScript 對應 2020 年的版本。這個版本不像 ES6 (ES2015)那樣包含大量新特性。但也添加了許多有趣且有用的特性。

本文以簡單的代碼示例來介紹 ES2020新特性。這樣,你可以很快理解這些新功能,而不需要多么復雜的解釋。

可選鏈操作符(Optional Chaining)

可選鏈 可讓我們在查詢具有多個層級的對象時,不再需要進行冗余的各種前置校驗。

日常開發中,當需要訪問嵌套在對象內部好幾層的屬性時,可能就會得到臭名昭著的錯誤Uncaught TypeError: Cannot read property...,這種錯誤,讓整段程序運行中止。

于是,你就要修改你的代碼來處理屬性鏈中每一個可能的undefined對象,比如:

  1. let nestedProp = obj && obj.first && obj.first.second

在訪問 obj.first.second 之前,要先確認 obj 和 obj.first 的值非 null(且不是 undefined)。

有了可選鏈式調用 ,可以大量簡化類似繁瑣的前置校驗操作,而且更安全:

  1. let nestedProp = obj?.first?.second

如果obj或obj.first是null/undefined,表達式將會短路計算直接返回undefined。

可選鏈操作符的支持情況:

空位合并操作符(Nullish coalescing Operator)

當我們查詢某個屬性時,經常會給沒有該屬性就設置一個默認的值,比如下面兩種方式:

  1. let c = a ? a : b // 方式1 
  2. let c = a || b // 方式2 

這兩種方式有個明顯的弊端,它都會覆蓋所有的假值,如(0, '', false),這些值可能是在某些情況下有效的輸入。

  1. let x = { 
  2. profile: { 
  3.   name'浪里行舟'
  4.   age: '' 
  5. console.log(x.profile.age || 18) //18 

上例中age的屬性為空字符串,卻被等同為假值,為了解決這個問題,ES2020誕生了個新特性--空位合并操作符,用 ?? 表示。如果表達式在??的左側運算符求值為 undefined 或 null,就返回其右側默認值。

  1. let c = a ?? b; 
  2. // 等價于let c = a !== undefined && a !== null ? a : b; 

例如有以下代碼:

  1. const x = null
  2. const y = x ?? 500; 
  3. console.log(y); // 500 
  4. const n = 0 
  5. const m = n ?? 9000; 
  6. console.log(m) // 0 

空位合并操作符的支持情況:

Promise.allSettled

我們知道 Promise.all 具有并發執行異步任務的能力。但它的最大問題就是如果參數中的任何一個promise為reject的話,則整個Promise.all 調用會立即終止,并返回一個reject的新的 Promise 對象。

  1. const promises = [ 
  2. Promise.resolve(1), 
  3. Promise.resolve(2), 
  4. Promise.reject('error'
  5. ]; 
  6. ​ 
  7. Promise.all(promises) 
  8. .then(responses => console.log(responses)) 
  9. .catch(e => console.log(e)) // "error" 

假如有這樣的場景:一個頁面有三個區域,分別對應三個獨立的接口數據,使用 Promise.all 來并發請求三個接口,如果其中任意一個接口出現異常,狀態是reject這會導致頁面中該三個區域數據全都無法出來,這個狀況我們是無法接受,Promise.allSettled的出現就可以解決這個痛點:

  1. Promise.allSettled([ 
  2. Promise.reject({ code: 500, msg: '服務異常' }), 
  3. Promise.resolve({ code: 200, list: [] }), 
  4. Promise.resolve({ code: 200, list: [] }) 
  5. ]).then(res => { 
  6. console.log(res) 
  7. /* 
  8.       0: {status: "rejected", reason: {…}} 
  9.       1: {status: "fulfilled", value: {…}} 
  10.       2: {status: "fulfilled", value: {…}} 
  11.   */ 
  12. // 過濾掉 rejected 狀態,盡可能多的保證頁面區域數據渲染 
  13. RenderContent( 
  14.   res.filter(el => { 
  15.     return el.status !== 'rejected' 
  16.   }) 
  17. }) 

Promise.allSettled跟Promise.all類似,其參數接受一個Promise的數組,返回一個新的Promise唯一的不同在于,它不會進行短路,也就是說當Promise全部處理完成后,我們可以拿到每個Promise的狀態,而不管是否處理成功。

Promise.allSettled的支持情況:

String.prototype.matchAll

如果一個正則表達式在字符串里面有多個匹配,現在一般使用g修飾符或y修飾符,在循環里面逐一取出。

  1. function collectGroup1 (regExp, str) { 
  2. const matches = [] 
  3. while (true) { 
  4.   const match = regExp.exec(str) 
  5.   if (match === null) break 
  6.   matches.push(match[1]) 
  7. return matches 
  8. console.log(collectGroup1(/"([^"]*)"/g, `"foo" and "bar" and "baz"`)) 
  9. // [ 'foo''bar''baz' ] 

值得注意的是,如果沒有修飾符 /g, .exec() 只返回第一個匹配。現在通過String.prototype.matchAll方法,可以一次性取出所有匹配。

  1. function collectGroup1 (regExp, str) { 
  2. let results = [] 
  3. for (const match of str.matchAll(regExp)) { 
  4.   results.push(match[1]) 
  5. return results 
  6. console.log(collectGroup1(/"([^"]*)"/g, `"foo" and "bar" and "baz"`)) 
  7. // ["foo""bar""baz"
  8. ​ 

上面代碼中,由于string.matchAll(regex)返回的是遍歷器,所以可以用for...of循環取出。

String.prototype.matchAll的支持情況:

Dynamic import

現在前端打包資源越來越大,前端應用初始化時根本不需要全部加載這些邏輯資源,為了首屏渲染速度更快,很多時候都是動態導入(按需加載)模塊,比如懶加載圖片等,這樣可以幫助您提高應用程序的性能。

其中按需加載這些邏輯資源都一般會在某一個事件回調中去執行:

  1. el.onclick = () => { 
  2. import('/modules/my-module.js'
  3.   .then(module => { 
  4.     // Do something with the module. 
  5.   }) 
  6.   .catch(err => { 
  7.     // load error; 
  8.   }) 

import()可以用于script腳本中,import(module) 函數可以在任何地方調用。它返回一個解析為模塊對象的 promise。

這種使用方式也支持 await 關鍵字。

  1. let module = await import('/modules/my-module.js'); 

通過動態導入代碼,您可以減少應用程序加載所需的時間,并盡可能快地將某些內容返回給用戶。

Dynamic import的支持情況:

BigInt

javascript 在 Math 上一直很糟糕的原因之一是只能安全的表示-(2^53-1)2^53-1的值,即Number.MIN_SAFE_INTEGERNumber.MAX_SAFE_INTEGER,超出這個范圍的整數計算或者表示會丟失精度。

  1. var num = Number.MAX_SAFE_INTEGER; // -> 9007199254740991 
  2. ​ 
  3. num = num + 1; // -> 9007199254740992 
  4. ​ 
  5. // 再次加 +1 后無法正常運算 
  6. num = num + 1; // -> 9007199254740992 
  7. ​ 
  8. // 兩個不同的值,卻返回了true 
  9. 9007199254740992 === 9007199254740993 // -> true 

于是 BigInt 應運而生,它是第7個原始類型,可安全地進行大數整型計算 你可以在BigInt上使用與普通數字相同的運算符,例如 +, -, /, *, %等等。

創建 BigInt 類型的值也非常簡單,只需要在數字后面加上 n 即可。例如,123 變為 123n。也可以使用全局方法 BigInt(value) 轉化,入參 value 為數字或數字字符串。

  1. const aNumber = 111; 
  2. const aBigInt = BigInt(aNumber); 
  3. aBigInt === 111n // true 
  4. typeof aBigInt === 'bigint' // true 
  5. typeof 111 // "number" 
  6. typeof 111n // "bigint" 

只要在數字末尾加上 n,就可以正確計算大數了:

  1. 1234567890123456789n * 123n; 
  2. // -> 151851850485185185047n 

不過有一個問題,在大多數操作中,不能將 BigInt與Number混合使用。比較Number和 BigInt是可以的,但是不能把它們相加。

  1. 1n < 2  
  2. // true 
  3. ​ 
  4. 1n + 2 
  5. // Uncaught TypeError: Cannot mix BigInt and other types, use explicit conversions 

BigInt的支持情況: 

globalThis

globalThis 是一個全新的標準方法用來獲取全局 this 。之前開發者會通過如下的一些方法獲取:

  • 全局變量 window:是一個經典的獲取全局對象的方法。但是它在 Node.js 和 Web Workers 中并不能使用

  • 全局變量 self:通常只在 Web Workers 和瀏覽器中生效。但是它不支持 Node.js。一些人會通過判斷 self 是否存在識別代碼是否運行在 Web Workers 和瀏覽器中

  • 全局變量 global:只在 Node.js 中生效

過去獲取全局對象,可通過一個全局函數:

  1. // ES10之前的解決方案 
  2. const getGlobal = function(){ 
  3. if(typeof self !== 'undefined'return self 
  4. if(typeof window !== 'undefined'return window 
  5. if(typeof global !== 'undefined'return global 
  6. throw new Error('unable to locate global object'
  7. ​ 
  8. // ES10內置 
  9. globalThis.Array(0,1,2) // [0,1,2] 
  10. ​ 
  11. // 定義一個全局對象v = { value:true } ,ES10用如下方式定義 
  12. globalThis.v = { value:true } 

globalThis 目的就是提供一種標準化方式訪問全局對象,有了 globalThis 后,你可以在任意上下文,任意時刻都能獲取到全局對象。

如果您在瀏覽器上,globalThis將為window,如果您在Node上,globalThis則將為global。因此,不再需要考慮不同的環境問題。

  1. // worker.js 
  2. globalThis === self 
  3. // node.js 
  4. globalThis === global 
  5. // browser.js 
  6. globalThis === window 

新提案也規定了,Object.prototype 必須在全局對象的原型鏈中。下面的代碼在最新瀏覽器中已經會返回 true 了:

  1. Object.prototype.isPrototypeOf(globalThis); // true 

globalThis的支持情況:

參考文章

作者簡介:

浪里行舟:碩士研究生,專注于前端。個人公眾號:「前端工匠」,致力于打造適合初中級工程師能夠快速吸收的一系列優質文章!

【51CTO原創稿件,合作站點轉載請注明原文作者和出處為51CTO.com】

責任編輯:龐桂玉 來源: 51CTO
相關推薦

2017-07-25 14:15:10

2025-05-19 00:06:00

編碼工具CursorAI

2020-08-05 10:13:14

JavaScript開發

2010-09-29 14:08:31

2010-08-03 13:30:39

AdobeFlexBu

2020-05-08 09:13:48

前端開發

2019-07-04 08:00:00

MySQL存儲開發

2018-09-30 14:20:03

編程語言Java新特性

2021-08-16 18:26:22

戴爾

2015-08-07 09:07:45

Java新特性面向未來

2023-11-24 07:50:35

后端網頁開發

2019-12-26 09:00:27

云計算悖論智能

2016-02-29 15:00:48

RSA/信息安全

2013-10-16 10:11:35

JavaScript項目框架

2011-08-10 10:41:19

虛擬化VMware ESXi

2022-05-01 12:19:33

云原生公有云云計算

2022-01-14 12:01:44

人工智能數字化技術

2019-07-18 16:46:29

Web開發趨勢Node.js

2015-09-17 17:37:57

工具程序開源

2023-06-29 17:53:00

VSCode插件程序
點贊
收藏

51CTO技術棧公眾號

虎白女粉嫩尤物福利视频| 国产精品久久久久久久小唯西川| 蜜臀av午夜一区二区三区| 手机福利在线| 美女爽到高潮91| 久久久99免费视频| 人妻无码中文久久久久专区| 日韩精品影院| 一区二区欧美国产| 日韩在线国产| 亚洲精品一级片| 日本不卡高清视频| 欧美激情影音先锋| 激情五月深爱五月| 无码日韩精品一区二区免费| 制服丝袜亚洲播放| aaa毛片在线观看| 欧美高清另类hdvideosexjaⅴ| 精品一区二区三区在线观看 | 九九热这里只有精品免费看| 国产污在线观看| 欧美激情福利| 福利一区视频在线观看| 福利网在线观看| 日本不卡免费播放| 丁香婷婷深情五月亚洲| 国产噜噜噜噜久久久久久久久| 国产精品av久久久久久无| 午夜视频在线观看精品中文| 欧洲一区二区av| 久草热视频在线观看| 大地资源网3页在线观看| 26uuu亚洲| 国产精品三区四区| 国产av无码专区亚洲av麻豆| 麻豆精品在线观看| 日韩免费在线播放| 欧美激情黑白配| 影音先锋一区| 欧美高清在线播放| 亚洲最大的黄色网址| 日韩毛片视频| 色av中文字幕一区| 97在线观看免费视频| 午夜精品福利影院| 日韩福利在线播放| 免费的av网站| 欧美精品中文字幕亚洲专区| 精品99久久久久久| 亚洲图片欧美另类| 国产成人高清精品免费5388| 日韩欧美不卡一区| 亚洲 自拍 另类 欧美 丝袜| 国产精品一区二区精品视频观看| 亚洲午夜在线视频| 小说区视频区图片区| 日本在线天堂| 综合欧美一区二区三区| 伊人天天久久大香线蕉av色| 免费a级人成a大片在线观看| 中文字幕av资源一区| 亚洲国产婷婷香蕉久久久久久99| www.天天干.com| 国产激情视频一区二区三区欧美| 97超级碰碰碰久久久| 日韩av男人天堂| 国产欧美成人| 日韩免费观看av| 一级黄色大片免费观看| 精品中文av资源站在线观看| 亚洲在线视频福利| 好吊视频一二三区| 99精品在线观看视频| 国产欧美韩日| 久蕉在线视频| 中文字幕欧美一| 精品人妻人人做人人爽| 欧美私密网站| 欧美专区日韩专区| 99精品视频免费版的特色功能| 神马电影网我不卡| 欧美日韩一区 二区 三区 久久精品| 999一区二区三区| 国产污视频在线播放| 欧美日韩亚洲一区二区| 国产av人人夜夜澡人人爽| 精品女同一区二区三区在线观看| 精品日韩视频在线观看| av片中文字幕| 成人乱码手机视频| 亚洲护士老师的毛茸茸最新章节| 成人免费黄色av| 果冻天美麻豆一区二区国产| 日韩电视剧在线观看免费网站| 国产吃瓜黑料一区二区| 亚洲区小说区图片区qvod按摩| 欧美成人欧美edvon| xxxxxx黄色| 日本a级不卡| 久久久噜噜噜久噜久久| 欧美brazzers| 成人福利电影精品一区二区在线观看 | 高清视频在线观看一区| 人妻视频一区二区三区| 日本一区免费视频| 久久99久久99精品| 欧美激情啪啪| 亚洲欧美日韩另类| 日本a级片视频| 视频一区二区三区入口| 999日本视频| 自拍视频在线| 一本色道**综合亚洲精品蜜桃冫| 日日鲁鲁鲁夜夜爽爽狠狠视频97 | 国内精品视频在线观看| 免费av在线一区| 波多野结衣一二区| a级精品国产片在线观看| 一区不卡字幕| 亚洲wwww| 日韩av在线不卡| 欧美日韩国产精品一区二区三区| 国产主播一区| 成人免费看黄网站| 国际av在线| 欧美性猛xxx| 久久精品aⅴ无码中文字字幕重口| 欧美久久亚洲| 亚洲人在线视频| 欧美不卡视频在线观看| 国产91在线看| 欧美 日韩 国产精品| 青青在线精品| 日韩一级黄色av| 成人免费毛片男人用品| 99riav久久精品riav| 成人免费观看在线| 日韩激情综合| 九九精品视频在线| 国产黄色片网站| 一区二区三区四区在线| 手机看片国产精品| 亚洲经典一区| 亚洲中国色老太| 18视频在线观看网站| 欧美一区二区三区视频在线| av资源在线免费观看| 久久精品国内一区二区三区 | 色老板在线视频一区二区| 欧美乱妇高清无乱码| 99在线观看精品视频| 亚洲免费av在线| 精品国产乱码久久久久久1区二区| av综合网址| 久久久最新网址| 少妇av一区二区| 欧美日韩国产色视频| 老牛影视av老牛影视av| 国产亚洲精品bv在线观看| 麻豆久久久9性大片| 日本美女一区| 在线观看不卡av| 亚洲综合精品国产一区二区三区 | 麻豆一区二区三| 午夜精品一区二区在线观看 | 欧美午夜在线一二页| 娇妻被老王脔到高潮失禁视频| 欧美日韩少妇| 精品国产福利| 欧美大胆性生话| 色狠狠久久aa北条麻妃| 99精品国产99久久久久久97| 亚洲男人的天堂网| 性农村xxxxx小树林| 性欧美videos另类喷潮| 四虎一区二区| 日韩欧美中文在线观看| 欧美性在线观看| av色图一区| 精品91自产拍在线观看一区| 国产成人无码av| 亚洲图片激情小说| 成人性生活免费看| 石原莉奈在线亚洲三区| 最近看过的日韩成人| 成人福利一区| 国产精品久久久久久久久男| h视频网站在线观看| 日韩免费看网站| 黄色在线视频网址| 亚洲女人小视频在线观看| 影音先锋黄色资源| 国内一区二区在线| 成人黄色av片| 希岛爱理一区二区三区| 久久av一区二区三区亚洲| 韩国精品视频在线观看 | 日本午夜在线观看| 麻豆9191精品国产| 狠狠精品干练久久久无码中文字幕| 日韩午夜视频在线| 久久久久久午夜| a√资源在线| 亚洲免费av网址| 国内精品偷拍视频| 精品视频资源站| 女人十八岁毛片| 亚洲黄一区二区三区| 久久精品无码一区| 成人av资源站| 亚洲综合在线一区二区| 秋霞国产午夜精品免费视频| 丁香花在线影院观看在线播放| www.成人网| 国产精品日韩欧美| 咪咪网在线视频| 欧美精品一区二区免费| 137大胆人体在线观看| 日韩国产精品亚洲а∨天堂免| 黄色一级片免费在线观看| 一区二区三区中文字幕精品精品 | 欧美xxxx做受欧美.88| 天堂在线一二区| 欧美xxx久久| 国产欧美第一页| 欧美日韩激情一区二区三区| 亚洲 欧美 成人| 香港成人在线视频| 久久久久久久久久一区二区三区| 成人h精品动漫一区二区三区| 九色自拍视频在线观看| 综合av在线| 天天干天天操天天干天天操| 久久视频在线| 视频一区二区三区免费观看| 日韩欧美四区| 久久国产一区二区| 亚洲欧洲av| 免费在线观看91| 群体交乱之放荡娇妻一区二区| 日韩免费观看网站| 涩涩视频网站在线观看| 97视频在线观看亚洲| 97人人在线视频| 性色av一区二区三区免费| 在线āv视频| 欧美高清videos高潮hd| a级片免费在线观看| 欧美国产精品人人做人人爱| 日本小视频在线免费观看| 欧美日韩成人精品| 69av成人| 青草青草久热精品视频在线观看| 在线播放免费av| 久久久久久有精品国产| 国产黄大片在线观看| 午夜精品一区二区三区在线播放| 97电影在线| 久久精品国产99国产精品澳门| 天堂av在线免费观看| 日韩av网址在线观看| 国产日本在线视频| 丝袜一区二区三区| 新版中文在线官网| 5252色成人免费视频| 欧美magnet| 91精品久久久久久久久久久久久久 | 久久av网站| 国产伦精品一区二区三区视频免费| 日本一区免费网站| 成人免费观看a| 六月丁香久久丫| 欧美日韩综合精品| 围产精品久久久久久久| 777久久精品一区二区三区无码| 成人免费av| 成人手机在线播放| 亚洲国产激情| 污污网站免费看| 岛国精品在线观看| 日本少妇高潮喷水xxxxxxx| 中日韩av电影| 精品午夜福利视频| 在线观看免费视频综合| 国产99久一区二区三区a片| 精品小视频在线| 国产福利在线播放麻豆| 91高清视频免费观看| 国产麻豆一区| 美女三级99| 欧美特黄一区| 自拍偷拍 国产| 成人蜜臀av电影| 国产成人精品视频免费| 亚洲成人资源网| 91精品国产乱码久久| 亚洲护士老师的毛茸茸最新章节| 污视频网站免费观看| 日韩中文第一页| 美女露胸视频在线观看| 亚洲综合日韩在线| 岳的好大精品一区二区三区| 国产香蕉一区二区三区| 久久综合影音| 午夜福利三级理论电影| 成人欧美一区二区三区小说| 欧美激情黑白配| 欧美精品一区二区三区蜜桃| 婷婷免费在线视频| 国产福利精品视频| 精品视频高潮| 国产精品视频一二三四区| 日本强好片久久久久久aaa| 久久人人妻人人人人妻性色av| 91在线国产福利| 久久久久无码国产精品不卡| 欧美精品第一页| 黄色av免费在线观看| 欧美精品videosex极品1| 亚洲精品第一| 亚洲国产一区二区精品视频 | 91成人综合网| 麻豆91精品91久久久的内涵| 久久人妻一区二区| 夜夜爽夜夜爽精品视频| 国产精品无码在线播放| 中文字幕9999| 日韩成人亚洲| 欧美中日韩一区二区三区| 在线视频精品| 99久久免费看精品国产一区| 亚洲自拍偷拍综合| 亚洲av无码一区二区乱子伦| 久久亚洲私人国产精品va| 成人在线观看免费视频| 日韩一区二区三区资源| 日韩vs国产vs欧美| 人人妻人人澡人人爽| 日韩欧美在线观看视频| 日本国产在线| 国产精品夫妻激情| 成人激情开心网| 在线免费观看视频黄| 国产精品三级视频| 在线观看中文字幕av| 最近2019年日本中文免费字幕 | 亚洲成人一区| 不卡中文字幕在线观看| 中文字幕佐山爱一区二区免费| 精品肉丝脚一区二区三区| 日韩精品一区二区三区三区免费| 神马亚洲视频| 日韩av免费在线播放| 国产伦一区二区三区| wwww.国产| 亚洲人妖av一区二区| 精品国产伦一区二区三区| 欧美激情一区二区三区成人| 久久亚洲道色| 成人黄色片视频| 欧美极品另类videosde| 91午夜交换视频| 欧美黑人巨大精品一区二区| 美女扒开腿让男人桶爽久久动漫| 自拍另类欧美| 国产成人精品亚洲午夜麻豆| 久久综合加勒比| 精品视频www| 91精品国产66| 一本大道东京热无码aⅴ| heyzo一本久久综合| 波多野结衣在线观看视频| 日韩一中文字幕| 狠狠久久伊人| 91网址在线播放| 亚洲精品国产高清久久伦理二区| 中国精品一区二区| 欧美成人中文字幕| 亚洲精品亚洲人成在线| 国产视频1区2区3区| 亚洲一区二区三区美女| 国产视频二区在线观看| 亚洲一区二区三区四区视频| 极品av少妇一区二区| 亚洲午夜精品久久久久久高潮| 精品成人国产在线观看男人呻吟| a在线观看免费| 青青草精品毛片| 一区二区电影在线观看| 丰满少妇一区二区三区| 欧美亚洲自拍偷拍| 丁香花在线高清完整版视频| 视频一区亚洲 | 波多野结衣三级视频| 午夜精品一区二区三区免费视频 | 亚洲片av在线| 精品国产一级| 韩国日本美国免费毛片| 亚洲国产精品麻豆| 亚洲s色大片|