久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長(zhǎng)資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

分享ES2019中值得收藏的8個(gè)有用功能

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

分享ES2019中值得收藏的8個(gè)有用功能

ES2019 規(guī)范是對(duì) JavaScript的小規(guī)模擴(kuò)展,但仍帶來(lái)了一些有趣的功能。本文向你展示八個(gè) ES2019 的功能,這些功能可以使你的開(kāi)發(fā)變得更輕松。

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


有時(shí)我們?cè)谔幚碜址畷r(shí)需要處理多余的空格。ES2020 增加了兩個(gè)功能:.trimStart()trimEnd() 方法可以幫你處理這些瑣事。

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

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

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

Function.prototype.toString()


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

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

// 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()


數(shù)組是 JavaScript 的基本組成部分之一。它們有時(shí)會(huì)引起很多問(wèn)題。當(dāng)你必須要處理多維數(shù)組時(shí)尤其如此。甚至將多維數(shù)組轉(zhuǎn)換為一維這樣看似簡(jiǎn)單的任務(wù)也可能很困難。

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

但是頁(yè)可以指定級(jí)數(shù),并在調(diào)用時(shí)作為參數(shù)傳遞。如果不確定需要多少級(jí),也可以使用 Infinity

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

Array.prototype.flatMap()

除了 flat() 方法之外,還有 flatMap()。可以把它看作是 flat() 的高級(jí)版本。區(qū)別在于 flatMap() 方法把 flat()map() 結(jié)合了起來(lái)。在展平數(shù)組時(shí),可以調(diào)用回調(diào)函數(shù)。

這樣就可以在展平過(guò)程中使用原始數(shù)組中的每個(gè)元素。當(dāng)在對(duì)數(shù)組進(jìn)行展平操作的同時(shí)又要修改內(nèi)容時(shí)很方便。

// 創(chuàng)建數(shù)組: const myArray = ['One word', 'Two words', 'Three words']  // 用 map() 將數(shù)組中的所有字符串拆分為單詞: // 注意:這將會(huì)創(chuàng)建多維數(shù)組。 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() 將數(shù)組中的所有字符串拆分為單詞: // 注意:這將會(huì)創(chuàng)建多維數(shù)組。 const myFlatWordArray = myArray.flatMap(str => str.split(' '))  console.log(myFlatWordArray) // Output: // [ 'One', 'word', 'Two', 'words', 'Three', 'words' ]

Object.fromEntries()


當(dāng)需要把某個(gè)對(duì)象轉(zhuǎn)換為數(shù)組時(shí),可以用 entries() 來(lái)完成。但是想要反向操作的話就困難了。ES2019 提供了 fromEntries() 來(lái)輕松解決這個(gè)問(wèn)題。

這個(gè)方法的作用很簡(jiǎn)單。它需要鍵值對(duì)的可迭代形式,例如數(shù)組或 Map,然后將其轉(zhuǎn)換為對(duì)象。

// 把數(shù)組轉(zhuǎn)換為對(duì)象: // 創(chuàng)建數(shù)組: const myArray = [['name', 'Joe'], ['age', 33], ['favoriteLanguage', 'JavaScript']] const myObj = Object.fromEntries(myArray) console.log(myObj) // Output: // { //   name: 'Joe', //   age: 33, //   favoriteLanguage: 'JavaScript' // }   // 把 Map 轉(zhuǎn)換為對(duì)象: // 創(chuàng)建 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 時(shí),還必須使用綁定。即使沒(méi)有使用該異常,你也必須將其作為參數(shù)傳遞。 在 ES2019 種,如果不想使用該異常,則可以使用不帶參數(shù)的 catch 塊。

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

格式正確的 JSON.stringify()


過(guò)去,當(dāng)對(duì)包含特定字符的東西使用 JSON.stringify() 時(shí),會(huì)得到格式不正確的 Unicode 字符串。從 U+D800到 U+DFFF 的編碼段會(huì)變成 “?”。更糟的是沒(méi)辦法把這些錯(cuò)誤的字符變回原樣。

ES2019 修復(fù)了 JSON.stringify() 方法。現(xiàn)在能夠?qū)δ切┯袉?wèn)題的代碼段進(jìn)行分類,并且可以將它們轉(zhuǎn)換回其原始表示形式。

Symbol.prototype.description


符號(hào)是在 ES2015(ES6)中引入的新數(shù)據(jù)類型。它們通常用于標(biāo)識(shí)對(duì)象屬性。 ES2019 增加了 description 屬性。這個(gè)屬性是只讀的,無(wú)法更改它的值。它用來(lái)返回給定符號(hào)的描述。

要牢記兩點(diǎn)。首先,創(chuàng)建符號(hào)時(shí)描述不是必須的,而是可選的。所以當(dāng)你嘗試訪問(wèn) description 時(shí),可能會(huì)得到除 undefined 之外的任何信息。如果你嘗試訪問(wèn)不帶描述的符號(hào)描述,則會(huì)得到 undefined(未定義)信息。

第二點(diǎn)是 description 是對(duì)符號(hào)本身的描述。它不是符號(hào)的標(biāo)識(shí)符。這意味著你不能使用現(xiàn)有的描述(即 description 屬性的值)來(lái)訪問(wèn)現(xiàn)有的符號(hào)。它只是為了更容易識(shí)別正在你正在使用的符號(hào)。

說(shuō)明:創(chuàng)建新的符號(hào)時(shí),可以通過(guò)將一些字符串作為參數(shù)傳遞給 Symbol() 對(duì)象來(lái)添加描述。如果留空,description 將會(huì)是 undefined

// 創(chuàng)建帶有描述的 Symbol: // 創(chuàng)建 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() 方法提供了另一種讀取符號(hào)描述的方式。它的缺點(diǎn)是在返回的字符串中還包含 Symbol()。另一個(gè)區(qū)別是 toString() 方法永遠(yuǎn)不會(huì)返回不存在的undefined 描述。

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

// 創(chuàng)建帶有描述的 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)
?
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
日韩精品诱惑一区?区三区| 免费观看久久久4p| 国产精品久久久久9999高清| 日韩国产高清在线| 国产日韩高清一区二区三区在线 | 色综合视频一区二区三区日韩| 蜜桃av一区二区在线观看| 日韩中文字幕| 麻豆精品在线视频| 999久久久91| 欧美高清不卡| 亚洲精品亚洲人成在线观看| 国产极品模特精品一二| 三上亚洲一区二区| 一区二区自拍| 青草综合视频| 中文字幕在线视频久| 欧美网站在线| 91精品国产自产观看在线| 精品一区二区三区的国产在线观看| 人人草在线视频| 日韩午夜免费| 欧美日韩99| 成人小电影网站| 蜜桃伊人久久| 国产精品极品在线观看| 99久久精品费精品国产| 亚洲+小说+欧美+激情+另类| 国产精品2023| 亚洲一区网站| 国产精品极品在线观看| 亚洲黑丝一区二区| 日韩激情啪啪| 亚洲成人精品| 欧美性www| 欧美日韩国产一区二区三区不卡| 国产欧美一区二区精品久久久| 成人国产精品久久| 中文字幕中文字幕精品| 大香伊人久久精品一区二区| 欧美日韩一区二区三区视频播放| 色综合视频一区二区三区日韩 | 国产视频一区三区| 欧美精品1区| 久久av一区| 欧美精品资源| 久久av日韩| 免费国产亚洲视频| 日韩中文首页| 美女视频黄 久久| 模特精品在线| 欧美 日韩 国产精品免费观看| 亚洲一二av| 99久久精品网| 福利一区和二区| 日本精品另类| 午夜欧美精品| 国产伊人久久| 国产精品免费99久久久| 久久国产精品久久久久久电车| 激情视频网站在线播放色| 日韩av中文字幕一区二区| 91久久久精品国产| 正在播放日韩精品| 免费一区二区三区在线视频| 亚洲精品高潮| 鲁大师影院一区二区三区| 水蜜桃久久夜色精品一区| 欧美日韩夜夜| 日本va欧美va瓶| 亚洲欧美日韩视频二区| 激情综合亚洲| 99国产精品一区二区| jizzjizz中国精品麻豆| 精品国产一区二| 欧美精品导航| 国产人成精品一区二区三| 日韩欧美高清一区二区三区| 久久国产成人| 蜜桃视频在线观看一区| 亚洲一区二区三区免费在线观看| 国产精品av一区二区| 成人国产精品一区二区网站| 久久精品国产福利| 国产乱人伦丫前精品视频 | 麻豆久久久久久久| 美女尤物国产一区| 欧美黑人做爰爽爽爽| 国产精品亚洲人成在99www| 日本一区免费网站| 日韩欧美中文在线观看| 日韩毛片网站| 日韩激情网站| 亚洲91网站| 日韩国产91| 国产极品一区| av资源中文在线| 欧美aa一级| 亚洲天堂成人| 久久成人亚洲| 日韩一区二区三区免费视频| 日本不卡中文字幕| 国产精品久久久久久久久免费高清| 国产精品一区2区3区| 麻豆成人综合网| 国产一区一一区高清不卡| 成人国产精品| 99热精品久久| 在线国产一区| 伊人久久大香伊蕉在人线观看热v| 最新国产精品视频| 国产伦精品一区二区三区在线播放| 精品一区二区男人吃奶 | 999国产精品视频| 国产一区久久| 免费欧美在线视频| 91成人在线| 日韩av在线播放网址| 91精品推荐| 蜜臀国产一区二区三区在线播放| 亚洲精品高潮| 精品国产成人| 亚洲成人国产| 日韩久久99| 国产精品毛片久久| 狠狠久久婷婷| 国产视频一区二区在线播放| 国产999精品在线观看| 亚洲国产专区校园欧美| 中文在线日韩| 国产一区丝袜| 国产亚洲一区在线| 日本不卡在线视频| 国产+成+人+亚洲欧洲在线| 一本大道色婷婷在线| 婷婷丁香综合| 欧美精品导航| 日韩视频一区| 国产精品天堂蜜av在线播放| www.com.cn成人| 伊人久久亚洲| 欧美日韩视频免费观看| 日韩精品中文字幕一区二区| 国产66精品| 深夜福利亚洲| 日韩高清中文字幕一区二区| 伊人精品久久| 亚洲三级欧美| 亚洲精品伦理| 日韩在线精品| 久久狠狠久久| 欧美成人高清| 国产一区三区在线播放| 亚洲精品高潮| 亚洲成av人片一区二区密柚| 国产亚洲一区| 欧美日韩国产精品一区二区亚洲| 国产精品亚洲综合在线观看| 午夜久久一区| 久久精品系列| 亚洲精品三级| 亚洲欧美一区在线| 高清一区二区三区av| 在线精品亚洲| 日本免费一区二区三区四区| 97se亚洲| 久久99伊人| 日韩国产在线| 欧美色综合网| 免费日本视频一区| 国内精品福利| 另类欧美日韩国产在线| 午夜天堂精品久久久久| 亚洲欧美网站| 91精品一区国产高清在线gif| 国内精品亚洲| 国产精品久久久一区二区| 亚洲天堂日韩在线| 影音国产精品| 欧美aa在线视频| 蜜臀91精品一区二区三区| 国产高清久久| 日韩欧美一区二区三区在线观看| 国产精品一区二区免费福利视频| 日韩精品1区| 美女毛片一区二区三区四区最新中文字幕亚洲| 1024精品久久久久久久久| 精品一区二区三区四区五区| 欧美亚洲二区| 久久狠狠亚洲综合| 蜜桃视频一区二区| 欧美另类专区| 国产综合欧美| 久久人人88| 老牛国内精品亚洲成av人片 | 国产网站在线| 麻豆精品在线观看| 日韩国产高清在线| 日韩免费精品| 日韩综合小视频|