gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網
最全最豐富的資訊網站

分享ES2019中值得收藏的8個有用功能

本篇文章給大家介紹ES2019 中 8 個非常有用的功能。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

分享ES2019中值得收藏的8個有用功能

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

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


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

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

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

// String.prototype.trimStart() 例子: // 處理不帶空格的字符串: 'JavaScript'.trimStart() // Output: //'JavaScript'  // 處理以空格開頭的字符串: ' JavaScript'.trimStart() // Output: //'JavaScript'  // 兩邊都留有空格的字符串 ' JavaScript '.trimStart() // Output: //'JavaScript '  // 以空格結尾的字符串 'JavaScript '.trimStart() // Output: //'JavaScript '   // String.prototype.trimEnd() 例子: // 處理不帶空格的字符串: 'JavaScript'.trimEnd() // Output: //'JavaScript'  // 處理以空格開頭的字符串: ' JavaScript'.trimEnd() // Output: //' JavaScript'  // 兩邊都留有空格的字符串 ' JavaScript '.trimEnd() // Output: //' JavaScript'  // 以空格結尾的字符串 'JavaScript '.trimEnd() // Output: //'JavaScript'

Function.prototype.toString()


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

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

// ES2019 之前: function myFunc/* is this really a good name? */() {   /* Now, what to do? */ }  myFunc.toString() // Output: // "function myFunc() {}"   // ES2019: function myFunc/* is this really a good name? */() {   /* Now, what to do? */ }  myFunc.toString() // Output: // "function myFunc/* is this really a good name? */() { //   /* Now, what to do? */ // }"

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


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

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

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

// 創建一個數組: const myArray = ['JavaScript', ['C', 'C++', ['Assembly', ['Bytecode']]]]  // 展平一級: let myFlatArray = myArray.flat(1)  // 輸出: console.log(myFlatArray) // Output: // [ 'JavaScript', 'C', 'C++', [ 'Assembly', [ 'Bytecode' ] ] ]  // 用參數 Infinity 展平: let myInfiniteFlatArray = myArray.flat(Infinity)  // 輸出: console.log(myInfiniteFlatArray) // Output: // [ 'JavaScript', 'C', 'C++', 'Assembly', 'Bytecode' ]

Array.prototype.flatMap()

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

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

// 創建數組: const myArray = ['One word', 'Two words', 'Three words']  // 用 map() 將數組中的所有字符串拆分為單詞: // 注意:這將會創建多維數組。 const myMappedWordArray = myArray.map(str => str.split(' '))  console.log(myMappedWordArray) // Output: // [ [ 'One', 'word' ], [ 'Two', 'words' ], [ 'Three', 'words' ] ]   // flatMap() 的例子: const myArray = ['One word', 'Two words', 'Three words']  // 用 map() 將數組中的所有字符串拆分為單詞: // 注意:這將會創建多維數組。 const myFlatWordArray = myArray.flatMap(str => str.split(' '))  console.log(myFlatWordArray) // Output: // [ 'One', 'word', 'Two', 'words', 'Three', 'words' ]

Object.fromEntries()


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

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

// 把數組轉換為對象: // 創建數組: const myArray = [['name', 'Joe'], ['age', 33], ['favoriteLanguage', 'JavaScript']] const myObj = Object.fromEntries(myArray) console.log(myObj) // Output: // { //   name: 'Joe', //   age: 33, //   favoriteLanguage: 'JavaScript' // }   // 把 Map 轉換為對象: // 創建 map: const myMap = new Map(   [['name', 'Spike'], ['species', 'dog'], ['age', 3]] ) const myObj = Object.fromEntries(myMap) console.log(myObj) // Output: // { //   name: 'Spike', //   species: 'dog', //   age: 3 // }

可選的 catch 綁定


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

// ES2019 之前: try {   // Do something. } catch (e) {     //忽略必需的e參數        //如果你不想用它,也應該保留。 }  // ES2019: try {   // Do something. } catch {   // 不需要添加任何參數 }

格式正確的 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

// 創建帶有描述的 Symbol: // 創建 Symbol 并添加描述: //注意:描述是"My first symbol." const mySymbol = Symbol('My first symbol.')  // 輸出 description 屬性的值: console.log(mySymbol.description) // Output: // 'My first symbol.'   // 讀取不存在的 Symbol: console.log(Symbol().description) // Output: // undefined   // 讀取定義為空字符串的描述: console.log(Symbol('').description) // Output: // ''

Symbol.prototype.toString()


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

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

// 創建帶有描述的 Symbol: const mySymbol = Symbol('REAMDE.')  // 輸出 description 屬性的值: console.log(mySymbol.toString()) // Output: // 'Symbol(REAMDE.)'  // 讀取不存在的 Symbol: console.log(Symbol().toString()) // Output: // 'Symbol()'   // 讀取定義為空字符串的描述: console.log(Symbol('').toString()) // Output: // 'Symbol()'

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
鲁一鲁一鲁一鲁一av| 六月婷婷激情综合| av网站在线观看不卡| av网站手机在线观看| 18禁裸男晨勃露j毛免费观看| 色爽爽爽爽爽爽爽爽| 日本美女久久久| 精品无码av无码免费专区| 亚洲免费视频播放| 草草草视频在线观看| 国产精品网站免费| 少妇人妻互换不带套| 在线看免费毛片| 激情五月五月婷婷| 久久久性生活视频| av污在线观看| 亚洲精品天堂成人片av在线播放| 免费在线黄网站| 青青草精品视频在线观看| 亚洲一二三av| 欧美一级欧美一级| 中文字幕第36页| 中国一级大黄大黄大色毛片| 国产特级淫片高清视频| 少妇网站在线观看| 青草视频在线观看视频| 国产精品亚洲a| 成人手机在线播放| 亚洲视频在线a| 久久久久久久久久久综合| 四季av一区二区| 97碰在线视频| 亚洲精品视频三区| 五十路熟女丰满大屁股| 亚洲欧美一区二区三区不卡| 男的插女的下面视频| 亚洲综合在线一区二区| 可以免费观看av毛片| 日韩一级特黄毛片| 91看片破解版| 欧美自拍小视频| 自慰无码一区二区三区| 91社在线播放| 黄色片免费网址| 亚洲 欧美 另类人妖| 国产亚洲欧美在线视频| 麻豆映画在线观看| 欧美视频亚洲图片| 日本激情视频在线播放| 国产真实乱子伦| 黄色免费视频大全| www在线观看免费| 18黄暴禁片在线观看| 男人日女人的bb| 国产高清免费在线| 亚洲图片 自拍偷拍| 五月天av在线播放| 久久久久国产一区| 男女男精品视频站| 国产视频手机在线播放| 在线免费观看视频黄| av免费网站观看| 国产精品无码专区av在线播放 | av网站在线不卡| 国产超级av在线| 欧美a在线视频| 熟妇人妻va精品中文字幕| 欧美成人一区二区在线观看| 波多野结衣综合网| 国产男女无遮挡| 天天碰免费视频 | 特级西西444| 日本人妻伦在线中文字幕| 色哺乳xxxxhd奶水米仓惠香| 日韩a级黄色片| 免费一级特黄特色毛片久久看| 亚洲 自拍 另类小说综合图区| 青青青免费在线| www.国产区| caoporm在线视频| 超碰人人爱人人| 欧美日韩一区二区在线免费观看| 国产精品亚洲αv天堂无码| 亚洲三级视频网站| www.日本久久| heyzo国产| 永久av免费在线观看| 精品国偷自产一区二区三区| 久久人妻精品白浆国产| 亚洲妇熟xx妇色黄蜜桃| 亚洲理论电影在线观看| 亚欧在线免费观看| 麻豆传媒网站在线观看| 亚洲精品无码久久久久久| 五月天视频在线观看| 欧美激情 国产精品| 亚洲激情在线看| 久久综合九色综合88i| 天天操狠狠操夜夜操| 国产精品www在线观看| 高清av免费看| 少妇无码av无码专区在线观看| 一级黄色特级片| 日日碰狠狠添天天爽超碰97| 999热精品视频| www.日本xxxx| 精品视频免费在线播放| 性生活免费观看视频| 国产又黄又猛又粗又爽的视频| 日本一本中文字幕| 三级黄色片播放| 9久久婷婷国产综合精品性色 | 老太脱裤子让老头玩xxxxx| 手机免费av片| 中文字幕国内自拍| 欧美丰满熟妇bbbbbb百度| 亚洲色婷婷久久精品av蜜桃| 成 人 黄 色 小说网站 s色| 鲁一鲁一鲁一鲁一色| 黄色特一级视频| 欧美精品一区二区性色a+v| 欧美男女交配视频| 牛夜精品久久久久久久| 黄色a级片免费| 国产精品乱码久久久久| 成人在线观看黄| 亚洲成熟丰满熟妇高潮xxxxx| 水蜜桃色314在线观看| bt天堂新版中文在线地址| 国产成a人亚洲精v品在线观看| 国产高清免费在线| 天天想你在线观看完整版电影免费| 中文字幕一区二区在线观看视频| 欧美成人三级在线播放| 高清av免费看| 亚洲综合123| 路边理发店露脸熟妇泻火| 久久www视频| 777777av| 三级a三级三级三级a十八发禁止| 手机视频在线观看| 国产精品嫩草影院8vv8| 国产一区二区三区播放| 毛片在线播放视频| 亚洲成人福利在线观看| 在线不卡一区二区三区| 国产精品igao网网址不卡| 欧美一级特黄aaaaaa在线看片| 日本黄色片一级片| 可以免费在线看黄的网站| 日韩成人av免费| 日韩亚洲欧美视频| 日韩视频在线免费看| 天堂av.com| av黄色在线网站| 污免费在线观看| 各处沟厕大尺度偷拍女厕嘘嘘| 亚洲一区在线不卡| 国产日韩欧美精品在线观看| 久久久国产欧美| 日韩成人三级视频| wwww.国产| 精品少妇在线视频| 精产国品一二三区| 毛片av免费在线观看| 久久99国产精品一区| 熟女人妇 成熟妇女系列视频| 91香蕉视频在线观看视频| 欧美韩国日本在线| 精品无码av无码免费专区| 免费一级特黄录像| 韩日视频在线观看| 91免费视频污| 国产九九在线观看| 成人免费在线小视频| 大陆极品少妇内射aaaaaa| 日韩av卡一卡二| 99精品视频在线看| 欧美不卡在线播放| 中文字幕在线中文| 91丨九色丨蝌蚪| 免费看污黄网站| 亚洲国产精品毛片av不卡在线| 国产传媒久久久| 潘金莲一级淫片aaaaa免费看| 黄色片在线免费| 欧美黄色一级片视频| av黄色在线网站| 国产妇女馒头高清泬20p多| 手机看片日韩国产| 日本黄色播放器| 毛毛毛毛毛毛毛片123| 国产三级三级看三级| www.日本xxxx| 亚洲污视频在线观看| 久久久精品麻豆| 天天操,天天操| 午夜剧场高清版免费观看 | 又色又爽又高潮免费视频国产| 免费看黄在线看|