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

ES2019 中8個非常有用的功能

開發 前端
ES2019 規范是對 JavaScript的小規模擴展,但仍帶來了一些有趣的功能。本文向你展示八個 ES2019 的功能,這些功能可以使你的開發變得更輕松。

ES2019 規范是對 JavaScript的小規模擴展,但仍帶來了一些有趣的功能。本文向你展示八個 ES2019 的功能,這些功能可以使你的開發變得更輕松。

[[386262]]

String.prototype.trimStart()和String.prototype.trimEnd()

有時我們在處理字符串時需要處理多余的空格。ES2020 增加了兩個功能:.trimStart()和 trimEnd() 方法可以幫你處理這些瑣事。

它們都可以幫助你修剪或刪除給定字符串中的空格。trimStart() 刪除字符串開頭的所有空格。trimEnd()將刪除字符串末尾的所有空格。不過要是想去除兩邊的空格呢?

有兩個選擇。第一種是同時使用這兩個 ES2019 功能。第二個是使用另一個字符串方法 trim()。兩種方式都能給你想要的結果。

  1. // String.prototype.trimStart() 例子: 
  2. // 處理不帶空格的字符串: 
  3. 'JavaScript'.trimStart() 
  4. // Output: 
  5. //'JavaScript' 
  6.  
  7. // 處理以空格開頭的字符串: 
  8. ' JavaScript'.trimStart() 
  9. // Output: 
  10. //'JavaScript' 
  11.  
  12. // 兩邊都留有空格的字符串 
  13. ' JavaScript '.trimStart() 
  14. // Output: 
  15. //'JavaScript ' 
  16.  
  17. // 以空格結尾的字符串 
  18. 'JavaScript '.trimStart() 
  19. // Output: 
  20. //'JavaScript ' 
  21.  
  22.  
  23. // String.prototype.trimEnd() 例子: 
  24. // 處理不帶空格的字符串: 
  25. 'JavaScript'.trimEnd() 
  26. // Output: 
  27. //'JavaScript' 
  28.  
  29. // 處理以空格開頭的字符串: 
  30. ' JavaScript'.trimEnd() 
  31. // Output: 
  32. //' JavaScript' 
  33.  
  34. // 兩邊都留有空格的字符串 
  35. ' JavaScript '.trimEnd() 
  36. // Output: 
  37. //' JavaScript' 
  38.  
  39. // 以空格結尾的字符串 
  40. 'JavaScript '.trimEnd() 
  41. // Output: 
  42. //'JavaScript' 

Function.prototype.toString()

函數的 toString() 方法已經存在了一段時間。它的作用是使你可以打印函數的代碼。ES2019 的不同之處在于它處理注釋和特殊字符(例如空格)的方式。

過去,toString() 方法刪除了注釋和空格。所以該函數的打印版本可能看起來與原始代碼不一樣。ES2019 的不會再發生這種情況。它返回的值將會與原始值匹配,包括注釋和特殊字符。

  1. // ES2019 之前: 
  2. function myFunc/* is this really a good name? */() { 
  3.   /* Now, what to do? */ 
  4.  
  5. myFunc.toString() 
  6. // Output: 
  7. // "function myFunc() {}" 
  8.  
  9.  
  10. // ES2019: 
  11. function myFunc/* is this really a good name? */() { 
  12.   /* Now, what to do? */ 
  13.  
  14. myFunc.toString() 
  15. // Output: 
  16. // "function myFunc/* is this really a good name? */() { 
  17. //   /* Now, what to do? */ 
  18. // }" 

Array.prototype.flat()和Array.prototype.flatMap()

數組是 JavaScript 的基本組成部分之一。它們有時會引起很多問題。當你必須要處理多維數組時尤其如此。甚至將多維數組轉換為一維這樣看似簡單的任務也可能很困難。

好消息是,ES2019 的兩個功能使這種操作變得更容易。第一個是 flat() 方法。在多維數組上使用時,它將轉換為一維。默認情況下,flat()只會將數組展平一級。

但是頁可以指定級數,并在調用時作為參數傳遞。如果不確定需要多少級,也可以使用 Infinity。

  1. // 創建一個數組: 
  2. const myArray = ['JavaScript', ['C', 'C++', ['Assembly', ['Bytecode']]]] 
  3.  
  4. // 展平一級: 
  5. let myFlatArray = myArray.flat(1) 
  6.  
  7. // 輸出: 
  8. console.log(myFlatArray) 
  9. // Output: 
  10. // [ 'JavaScript', 'C', 'C++', [ 'Assembly', [ 'Bytecode' ] ] ] 
  11.  
  12. // 用參數 Infinity 展平: 
  13. let myInfiniteFlatArray = myArray.flat(Infinity) 
  14.  
  15. // 輸出: 
  16. console.log(myInfiniteFlatArray) 
  17. // Output: 
  18. // [ 'JavaScript', 'C', 'C++', 'Assembly', 'Bytecode' ] 

Array.prototype.flatMap()

除了 flat() 方法之外,還有 flatMap()。可以把它看作是 flat() 的高級版本。區別在于 flatMap() 方法把 flat() 與 map() 結合了起來。在展平數組時,可以調用回調函數。

這樣就可以在展平過程中使用原始數組中的每個元素。當在對數組進行展平操作的同時又要修改內容時很方便。

  1. // 創建數組: 
  2. const myArray = ['One word', 'Two words', 'Three words'] 
  3.  
  4. // 用 map() 將數組中的所有字符串拆分為單詞: 
  5. // 注意:這將會創建多維數組。 
  6. const myMappedWordArray = myArray.map(str => str.split(' ')) 
  7.  
  8. console.log(myMappedWordArray) 
  9. // Output: 
  10. // [ [ 'One', 'word' ], [ 'Two', 'words' ], [ 'Three', 'words' ] ] 
  11.  
  12.  
  13. // flatMap() 的例子: 
  14. const myArray = ['One word', 'Two words', 'Three words'] 
  15.  
  16. // 用 map() 將數組中的所有字符串拆分為單詞: 
  17. // 注意:這將會創建多維數組。 
  18. const myFlatWordArray = myArray.flatMap(str => str.split(' ')) 
  19.  
  20. console.log(myFlatWordArray) 
  21. // Output: 
  22. // [ 'One', 'word', 'Two', 'words', 'Three', 'words' ] 

Object.fromEntries()

當需要把某個對象轉換為數組時,可以用 entries() 來完成。但是想要反向操作的話就困難了。ES2019 提供了 fromEntries() 來輕松解決這個問題。

這個方法的作用很簡單。它需要鍵值對的可迭代形式,例如數組或 Map,然后將其轉換為對象。

  1. // 把數組轉換為對象: 
  2. // 創建數組: 
  3. const myArray = [['name', 'Joe'], ['age', 33], ['favoriteLanguage', 'JavaScript']] 
  4. const myObj = Object.fromEntries(myArray) 
  5. console.log(myObj) 
  6. // Output: 
  7. // { 
  8. //   name: 'Joe', 
  9. //   age: 33, 
  10. //   favoriteLanguage: 'JavaScript' 
  11. // } 
  12.  
  13.  
  14. // 把 Map 轉換為對象: 
  15. // 創建 map: 
  16. const myMap = new Map( 
  17.   [['name', 'Spike'], ['species', 'dog'], ['age', 3]] 
  18. const myObj = Object.fromEntries(myMap) 
  19. console.log(myObj) 
  20. // Output: 
  21. // { 
  22. //   name: 'Spike', 
  23. //   species: 'dog', 
  24. //   age: 3 
  25. // } 

可選的 catch 綁定

以前使用 try ... catch 時,還必須使用綁定。即使沒有使用該異常,你也必須將其作為參數傳遞。在 ES2019 種,如果不想使用該異常,則可以使用不帶參數的 catch 塊。

  1. // ES2019 之前: 
  2. try { 
  3.   // Do something. 
  4. } catch (e) { 
  5.  //忽略必需的e參數 
  6.     //如果你不想用它,也應該保留。 
  7.  
  8. // ES2019: 
  9. try { 
  10.   // Do something. 
  11. } catch { 
  12.   // 不需要添加任何參數 

格式正確的 JSON.stringify()

過去,當對包含特定字符的東西使用 JSON.stringify() 時,會得到格式不正確的 Unicode 字符串。從 U+D800到 U+DFFF 的編碼段會變成 “�”。更糟的是沒辦法把這些錯誤的字符變回原樣。

ES2019 修復了 JSON.stringify() 方法。現在能夠對那些有問題的代碼段進行分類,并且可以將它們轉換回其原始表示形式。

Symbol.prototype.description

符號是在 ES2015(ES6)中引入的新數據類型。它們通常用于標識對象屬性。ES2019 增加了 description 屬性。這個屬性是只讀的,無法更改它的值。它用來返回給定符號的描述。

要牢記兩點。首先,創建符號時描述不是必須的,而是可選的。所以當你嘗試訪問 description 時,可能會得到除 undefined 之外的任何信息。如果你嘗試訪問不帶描述的符號描述,則會得到 undefined(未定義)信息。

第二點是 description 是對符號本身的描述。它不是符號的標識符。這意味著你不能使用現有的描述(即 description 屬性的值)來訪問現有的符號。它只是為了更容易識別正在你正在使用的符號。

說明:創建新的符號時,可以通過將一些字符串作為參數傳遞給 Symbol() 對象來添加描述。如果留空,description 將會是 undefined。

  1. // 創建帶有描述的 Symbol: 
  2. // 創建 Symbol 并添加描述: 
  3. //注意:描述是"My first symbol." 
  4. const mySymbol = Symbol('My first symbol.') 
  5.  
  6. // 輸出 description 屬性的值: 
  7. console.log(mySymbol.description) 
  8. // Output: 
  9. // 'My first symbol.' 
  10.  
  11.  
  12. // 讀取不存在的 Symbol: 
  13. console.log(Symbol().description) 
  14. // Output: 
  15. // undefined 
  16.  
  17.  
  18. // 讀取定義為空字符串的描述: 
  19. console.log(Symbol('').description) 
  20. // Output: 
  21. // '' 

Symbol.prototype.toString()

toString() 方法提供了另一種讀取符號描述的方式。它的缺點是在返回的字符串中還包含 Symbol()。另一個區別是 toString() 方法永遠不會返回不存在的undefined描述。

使用 description 的另一個原因是:如果你有一個沒有說明的 Symbol 并用了 toString() 方法,仍將得到 Symbol() 部分。如果描述為空字符串,也將獲得此信息。這樣就基本上不可能區分不存在的描述和用作描述的空字符串。

  1. // 創建帶有描述的 Symbol: 
  2. const mySymbol = Symbol('REAMDE.') 
  3.  
  4. // 輸出 description 屬性的值: 
  5. console.log(mySymbol.toString()) 
  6. // Output: 
  7. // 'Symbol(REAMDE.)' 
  8.  
  9. // 讀取不存在的 Symbol: 
  10. console.log(Symbol().toString()) 
  11. // Output: 
  12. // 'Symbol()' 
  13.  
  14.  
  15. // 讀取定義為空字符串的描述: 
  16. console.log(Symbol('').toString()) 
  17. // Output: 
  18. // 'Symbol()' 

 

責任編輯:趙寧寧 來源: 前端先鋒
相關推薦

2013-11-05 10:03:22

Eclipse功能

2020-10-29 10:00:55

Python函數文件

2012-03-01 09:15:41

HTML 5

2017-08-02 13:32:18

編程Java程序片段

2011-07-07 17:16:43

PHP

2009-03-24 14:23:59

PHP類庫PHP開發PHP

2023-02-19 15:22:22

React技巧

2009-05-18 16:58:56

Java代碼片段

2022-09-02 23:08:04

JavaScript技巧開發

2018-08-03 10:02:05

Linux命令

2023-06-13 15:15:02

JavaScript前端編程語言

2013-06-14 14:57:09

Java基礎代碼

2013-08-21 10:31:22

HTML5工具

2013-08-12 15:00:24

LinuxLinux命令

2022-06-27 19:01:04

Python應用程序數據

2009-02-09 11:20:06

Windows7Windows

2013-08-13 10:46:51

LinuxLinux命令

2011-04-06 14:08:14

jQuery

2012-04-17 09:44:08

JavaScript

2015-08-12 11:09:42

開發者設計原則
點贊
收藏

51CTO技術棧公眾號

刘亦菲久久免费一区二区| chinese全程对白| 在线能看的av网址| 99久久婷婷国产综合精品| 国产成人精品视频在线观看| 国产又粗又猛又爽又黄的视频小说| 只有精品亚洲| 亚洲国产va精品久久久不卡综合| 欧美二区在线| 国产视频在线观看免费 | 日本a级片在线播放| 水莓100国产免费av在线播放| 视频一区中文字幕国产| 久久视频在线播放| 欧美多人猛交狂配| 一区视频网站| 欧美日韩国产123区| 成人免费观看在线| 日本欧美在线视频免费观看| 不卡电影免费在线播放一区| 国产日本欧美在线观看 | 亚洲乱码视频| 久久在精品线影院精品国产| 午夜精产品一区二区在线观看的| 97人人澡人人爽91综合色| 欧美在线色视频| 奇米影视亚洲色图| 黄色免费在线观看网站| 久久综合视频网| 成人做爰66片免费看网站| a片在线免费观看| 宅男噜噜噜66一区二区| 欧美高清不卡在线| 永久免费看片直接| 日韩成人精品一区| 精品一区二区三区三区| 熟妇高潮一区二区| 久久爱www.| 欧美军同video69gay| 北条麻妃在线一区| 中日韩脚交footjobhd| 亚洲午夜电影在线观看| 国产一级黄色录像片| 老司机在线永久免费观看| 国产亚洲一区二区三区在线观看| 国产一区喷水| 好吊视频一区二区三区| 国产精品一级片| 亚洲综合精品伊人久久| 国产国语亲子伦亲子| 精品无人码麻豆乱码1区2区 | 久久成人精品一区二区三区| 精品手机在线视频| 成人6969www免费视频| 在线亚洲午夜片av大片| 欧美性受xxxx黑人| 日韩精品欧美激情一区二区| 中文字幕欧美精品在线| 2019男人天堂| 久久裸体网站| 久久躁狠狠躁夜夜爽| www深夜成人a√在线| 亚洲欧美在线专区| 欧美国产日韩一区二区在线观看| 欧美国产在线看| 一区福利视频| 91av在线播放视频| 成人毛片一区二区三区| 日本亚洲最大的色成网站www| 国产精品免费一区| 97精品久久人人爽人人爽| 国产在线播放一区| 国产另类第一区| 国产在线网站| 国产精品美女一区二区| 公共露出暴露狂另类av| 国内小视频在线看| 色综合av在线| 午夜一区二区视频| 99re8这里有精品热视频免费 | 亚洲一区二区久久久久久久| 亚洲成人第一区| 99re成人精品视频| 亚洲欧美电影在线观看| 在线观看三级视频| 精品久久久久久久久中文字幕| 日韩中文字幕免费在线| 高清久久精品| 日韩激情视频在线| 一区二区三区在线播放视频| 激情久久五月| 国产精品久久久久不卡| 国产极品久久久| 久久一留热品黄| 五月天av影院| 在线观看的黄色| 91精品福利在线一区二区三区| 国产高清成人久久| 色喇叭免费久久综合网| 久久久影视精品| 中文字幕一二区| 成人午夜精品在线| 一个色的综合| 在线观看特色大片免费视频| 3d成人h动漫网站入口| 中国一级特黄录像播放| 日韩av免费大片| 51精品在线观看| 99久久亚洲精品日本无码| 91在线观看免费视频| 糖心vlog在线免费观看| 亚洲成人一区在线观看| 精品乱人伦一区二区三区| 毛片久久久久久| 日韩一级精品| 91视频网页| 在线观看免费版| 色偷偷88欧美精品久久久| xxxx国产视频| 偷偷www综合久久久久久久| 欧美一性一乱一交一视频| 国产一区二区在线播放视频| 久久久精品天堂| 日本午夜激情视频| 视频一区中文字幕精品| 日韩在线视频国产| jizz国产在线观看| 99久久精品国产毛片| 大陆极品少妇内射aaaaaa| 伊人久久大香线蕉综合影院首页| 亚洲欧美日韩综合| 久久一区二区三区视频| jlzzjlzz国产精品久久| 日本一级黄视频| 久久天堂久久| 色噜噜狠狠色综合网图区| 一级片在线免费播放| 国产亚洲欧美在线| 妞干网在线视频观看| 999精品视频在这里| 久久久久久久久久久免费| 国产免费无遮挡| 亚洲日本一区二区三区| 鲁一鲁一鲁一鲁一av| 成人看的羞羞网站| 国产精品久久久久久久久久久不卡| 亚州男人的天堂| 精品久久久久久久中文字幕| 麻豆av免费观看| 亚洲一区二区免费看| 久久婷婷人人澡人人喊人人爽| 99色在线观看| 日韩成人xxxx| 日本午夜视频在线观看| 91捆绑美女网站| 日本在线xxx| 秋霞蜜臀av久久电影网免费| 992tv成人免费视频| 视频一区二区在线播放| 91国产精品成人| 免费一级suv好看的国产网站| 美女视频黄 久久| 亚洲成年人专区| 日韩综合一区二区三区| 久久理论片午夜琪琪电影网| 视频污在线观看| 一本色道综合亚洲| 天天摸日日摸狠狠添| 国产在线看一区| 999一区二区三区| 日韩国产在线不卡视频| 国模极品一区二区三区| 黄色大片在线免费观看| 欧美日韩一区视频| 麻豆亚洲av成人无码久久精品| 成人精品免费看| 37pao成人国产永久免费视频| 欧美色图激情小说| 亚洲综合国产精品| 在线黄色的网站| 久久精品国产亚洲7777| 后进极品白嫩翘臀在线视频| 色综合 综合色| 国产美女高潮视频| jiyouzz国产精品久久| 91看片在线免费观看| 欧美日韩专区| 日本一区免费观看| 精品网站999| 日本精品一区二区三区在线播放视频| 男人天堂久久久| 亚洲国产精品久久精品怡红院| 国产成人av免费| 一区二区三区日本| 国产一区二区三区四区五区六区| 激情偷乱视频一区二区三区| 国产不卡一区二区视频| 手机在线电影一区| 国产一区福利视频| 亚洲综合视频| 日韩av免费看| 国产蜜臀av在线播放| 在线观看中文字幕亚洲| 少妇人妻一区二区| 欧美日韩一区精品| 欧美一级片免费在线观看| 亚洲视频资源在线| 日本少妇高潮喷水xxxxxxx| 国产69精品久久久久毛片| 午夜免费一区二区| 亚洲视频二区| 人妻无码一区二区三区四区| 成人国产精品一级毛片视频| 精品国产一区二区三区久久久久久| 日韩成人精品一区二区三区| 欧美一级淫片videoshd| 黄色小说在线播放| 久久精品亚洲一区| 国产精品秘入口| 日韩hd视频在线观看| 性欧美8khd高清极品| 欧美乱妇23p| 久久久精品视频网站| 亚洲成av人在线观看| 精品国产视频一区二区三区| 欧美高清在线精品一区| 在线 丝袜 欧美 日韩 制服| 国产成人av福利| 熟妇女人妻丰满少妇中文字幕| 美洲天堂一区二卡三卡四卡视频| 99久久激情视频| 亚洲欧美日韩在线观看a三区| 9色porny| 国产一区二区中文| 久操手机在线视频| 一本一道久久综合狠狠老| 小说区视频区图片区| 成人激情在线| 亚洲精品tv久久久久久久久| 国产中文精品久高清在线不| 久久一区二区三区av| 欧美精品密入口播放| 国产乱码精品一区二区三区不卡| 日韩激情综合| 99久久自偷自偷国产精品不卡| 国产美女精品视频免费播放软件| 成人激情黄色网| 国产精品欧美一区二区三区不卡| 91欧美日韩一区| 97久久精品一区二区三区的观看方式 | 国产高清一区二区三区四区| 国产色91在线| 免费看的黄色录像| 中文字幕中文字幕一区| 国产又色又爽又高潮免费 | 在线看成人av| 精品国产91久久久| 欧美h在线观看| 色欧美日韩亚洲| 中文字幕人妻一区二区三区视频| 欧美日韩一二三| 国产精品女同一区二区| 日韩欧美黄色影院| 日本毛片在线观看| 亚洲色图美腿丝袜| 欧美成人二区| 欧美成人免费大片| 黄视频免费在线看| 秋霞av国产精品一区| 久久久免费人体| 97超级在线观看免费高清完整版电视剧| 综合成人在线| 久久国产精品一区二区三区| 国产麻豆精品久久| 成人性做爰片免费视频| 亚洲婷婷在线| 污污视频网站免费观看| 韩国欧美国产一区| 日本黄色动态图| 欧美国产日韩亚洲一区| 亚洲综合视频网站| 精品日本美女福利在线观看| 天天干天天插天天射| 日韩视频免费观看高清完整版| 日日夜夜精品免费| 精品国产一区二区三区久久久| 久草成色在线| 国产精品久久久久久一区二区| 国产电影一区| 日本一区二区三区视频免费看| 五月天综合网站| 欧美日韩二三区| 寂寞少妇一区二区三区| 亚洲中文字幕无码av| 国产精品三级电影| 日产精品久久久久| 欧美日韩成人在线一区| 亚洲三级黄色片| 免费av一区二区| 国产麻豆久久| 狠狠色狠狠色综合人人| 一区二区日韩欧美| 日韩精品一区二区三区不卡| 国产.欧美.日韩| 成人欧美一区二区三区黑人一| 欧美日韩国产一区在线| 亚洲综合精品在线| 亚洲精品动漫100p| 污视频在线免费观看网站| 国产精品久久综合av爱欲tv| 高清一区二区三区| 色哺乳xxxxhd奶水米仓惠香| 日韩成人dvd| 51调教丨国产调教视频| 一区二区三区在线观看动漫| 中文有码在线播放| 精品伊人久久97| 超黄网站在线观看| 91在线免费看网站| 水蜜桃久久夜色精品一区| 国产免费毛卡片| 成人污视频在线观看| 国产精品免费人成网站酒店| 欧美少妇xxx| 国产一区二区影视| 日本精品久久久久影院| 日韩黄色网络| www插插插无码视频网站 | 97netav| 一本一道久久综合狠狠老| 天堂网在线免费观看| 国产欧美日韩三区| 亚洲av无码不卡| 亚洲欧美国产精品| 亚洲欧美小说色综合小说一区| 国产亚洲欧美一区二区三区| 国产一区二区三区四区老人| 手机看片国产精品| 亚洲美女屁股眼交| 国产视频第二页| 欧美裸身视频免费观看| 精品国产一区二区三区性色av| 国产又粗又爽又黄的视频| 精品一区二区久久| 中文字幕电影av| 欧美一二三在线| 欧美人与性动交α欧美精品图片| 亚洲影院在线看| 欧美二区视频| 中文字幕99页| 五月天一区二区| 日本亚洲欧美| 国产精品成人免费电影| 精品一区二区三区的国产在线观看| 久久精品午夜福利| 中文文精品字幕一区二区| 亚洲手机在线观看| 久久精视频免费在线久久完整在线看| 在线播放成人| 日本丰满大乳奶| 岛国av在线一区| 日本特级黄色片| 一本色道久久综合亚洲精品小说 | 黄色av日韩| 亚洲国产精品自拍视频| 91久久精品日日躁夜夜躁欧美| 国产粉嫩一区二区三区在线观看| 国产剧情久久久久久| 欧美一区二区三区久久精品茉莉花 | 国产日韩电影| 亚洲色图自拍| 高清shemale亚洲人妖| 国产精品免费av一区二区| 亚洲人精选亚洲人成在线| 日韩久久一区| 国产黄色片免费在线观看| 26uuu精品一区二区| 曰批又黄又爽免费视频| 欧美福利视频在线| 国产精品免费大片| 樱花草www在线| 欧美日韩激情视频| 欧美性videos| 狠狠色伊人亚洲综合网站色| 蜜臀精品久久久久久蜜臀| 国产一级片免费看| 亚洲欧美日韩中文在线制服| 国产不卡精品| 激情五月亚洲色图| 亚洲综合免费观看高清完整版| 欧美欧美欧美| 99在线看视频| 日本亚洲天堂网| 日本一级一片免费视频| 最近2019免费中文字幕视频三 | 黑人巨大精品欧美一区| 久久久久99精品成人片三人毛片| 久久精品国产免费观看| 亚洲小说图片| ass极品水嫩小美女ass|