成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

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

分享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號
部长的夫人的味道中字| WWW夜片内射视频在观看视频| 制服丝袜长腿无码专区第一页| 精品国产一区二区三区无码| 被老头侵犯的人妻| 一本到高清视频在线观看丶| 亚洲AVAV黄网站| 天天躁日日躁狠狠躁AV中文| 无码中文字幕在线播放2| 日本乱人伦AⅤ精品潮喷| 色老头BGMBGMBGM| 午夜A成V人电影| 亚洲欧美日韩国产精品一区二区| 一碰就有水的女人男人喜欢?| ◇一本大道香蕉中文在线 | 国产成人精品一区二区三区| 国产又色又刺激高潮视频| 精品无码成人网站久久久久久 | 伊人久久大香线蕉综合网站| A级毛片免费无码观看、、| 夫では満足できない人妻| 国产在线成人一区二区三区| 久久夜色精品国产噜噜麻豆| 欧美又粗又长XXXXBBBB疯| 特黄熟妇丰满人妻无码| 亚洲乱码一区AV春药高潮| 西方137大但人文艺术| 亚洲中文字幕成人无码| CHINASEXSEX高潮对白| 国产精彩乱子真实视频| 精品欧洲AV无码一区二区| 国外精产品W灬源码16| 老头猛的挺进她莹莹的体导演是谁 | 国产98色在线 | 日韩| 极品少妇被黑人白浆直流| 黑人上司与人妻激烈中文字幕| 撅高屁股乖乖被学长CAO男男| 久久九九久精品国产88| 热久久99这里有精品综合久久 | 别揉我奶头~嗯~啊~免费视频| 国产美女裸体丝袜喷水视频| 邻居少妇张开双腿让我爽一夜 | 韩国三级大乳在线观看| 内射人妻无码色AV| 无码人妻精品一区二区三区蜜桃91| 野花香高清视频在线观看免费| 超碰色偷偷男人的天堂| 精品国产自在现线看久久| 人妻少妇精品无码专区芭乐视网| 亚洲AV成人片无码色欲AV自慰| 2021最新久久久视精品爱| 国产精品呻吟AV久久高潮| 蜜桃视频一区二区三区| 无码人妻丰满熟妇区BBBBXX| 中国BGMBGMBGM老妇和青年交| 公司办公室的秘书3| 久久久久成人精品无码| 熟女CHACHACHA性少妇| 一二三四免费观看在线电影二| 粉嫩虎白女流水白浆在线播放| 久久久久久久99精品国产片| 熟妇人妻av无码一区二区三区 | 抖抈APP入口免费| 久久人爽人人爽人人片AV| 免费观看的AV毛片的网站| 亭亭玉立国色天香四月天| 18禁自慰网址进入| 国偷自产AⅤ一区二区三区| 日本护士体内SHE精2╳╳╳| 亚洲中文字幕日产乱码小说| 国产成人A∨麻豆精品| 男人激烈吮乳吃奶到高潮视频 | 香蕉免费一区二区三区| 99久热RE在线精品视频| 加勒比久久综合久久鬼色88| 日本一区二区三区免费播放| 一二三四视频社区在线| 国产免费久久精品99久久| 欧美一区二期三区视频| 亚洲影院丰满少妇中文字幕无码 | 久久人妻蜜桃一区二区三区| 无码人妻一区二区三区免费AV| AV香港经典A毛片免费观看| 久久国产精品免费一区| 无码人妻丰满熟妇惹区| 被公侵犯肉体中文字幕电影| 狂猛欧美激情性XXXX在线观看| 亚洲AV成人精品日韩一区18p| 超碰CAOPORON入口| 免费午夜无码18禁无码影视| 亚洲精品无码专区久久久| 国产精品扒开腿做爽爽爽视频| 人扒开女人添高潮的视频嗯啊| 老妇擦她毛荫荫的玥户| 亚洲AV成人AV天堂| 寡妇下面好黑好毛| 欧式春画图片大全欣赏简单| 岳女四人共侍一夫婷婷| 后Λ式动态后Λ式动态图AV | 成人免费视频无码专区| 免费观看亚洲人成网站| 亚洲色WWW成人永久网址| 88国产精品视频一区二区三区 | 夜先锋AV资源网站| 狠狠爱天天综合色欲网| 无遮挡无码H纯肉动漫在线观看| 从厨房一路顶撞到卧室门好吗| 国产午夜亚洲精品理论片八戒| 色偷偷色噜噜狠狠网站30根| CSGO白嫖网站| 内射射满骚B含着小说| 曰韩无码二三区中文字幕| 久久66热人妻偷产精品9| 亚洲AV无码乱码麻豆精品国产 | 女被啪到高潮的GIF动态图无遮 | 在教室伦流澡到高潮HGL视频| 精品深夜AV无码一区二区老年| 亚洲AV无码秘 蜜桃牛牛| 国产精品免费看久久久无码| 熟妇人妻不卡无码一区| 国产AV大学生第一次破| 色狠狠熟女AV一区二区三区| 成年免费手机毛片免费看无码| 清区二三区国产好的精华液| AV无码久久久久不卡网站下载| 免费无码又爽又刺激激情视频软件| 婬乱丰满熟妇XXXXX性69| 久久久无码精品午夜| 亚洲制服丝袜无码AV在线| 久久精品国产99精品国产亚洲性 | 亚洲老熟女 @ TUBEUM TV| 国语自产拍精品香蕉在线播放| 亚洲AV激情高潮抽搐乱色| 国产无套无码AⅤ在线观看| 西西人体444www大胆无码视频| 国产老熟女八AV| 亚洲AV成人片无码| 激情综合激情五月俺也去| 亚洲精品无码久久不卡| 久久久精品无码中文天美| 一夲道无码人妻精品一区二区| 久热爱精品视频线路一| _97夜夜澡人人爽人人喊_欧美| 国产美女极度色诱视频WWW| 无码熟妇人妻AV影音先锋| 国产男男激情VIDEOSGAY| 亚洲AⅤ永久无码精品AA| 精品高潮呻吟99AV无码| 亚洲一线产区二线产区区别在哪 | 天天躁夜夜躁狠狠夜夜| 国产精品一线二线三线有什么区别| 亚洲AⅤ无码成人网站国产APP | 人妻少妇精品久久| 工口全彩H肉无遮挡无翼乌| 无码人妻在线视频| 精品国产乱码久久久久久小说 | 人人妻人人澡人人爽欧美精品 | 小12箩利洗澡无码视频网站| 娇小6一8XXXXX| 在线天堂中文最新版WWW下载| 欧美精品色婷婷五月综合| 成人综合婷婷国产精品久久| 年轻的小婊孑4中文字幕电影| DIPTYQUE含羞草香薰| 熟妇人妻VA精品中文字幕| 国产自产V一区二区三区C| 野花社区大全免费观看3| 欧美极品少妇XXXXⅩO69| 成午夜福利人试看120秒| 小婷又紧又嫩又窄又多水| 久久精品夜色噜噜亚洲A∨| 2021久久天天躁狠狠躁夜夜 | 亚洲精品无码国产| 蜜臀成人片免费视频在线观看| 超碰97久久国产精品牛牛| 亚洲18色成人网站WWW| 老色鬼久久亚洲AV综合0男男| 拔萝卜高清视频大全免费观看| 无码人妻丰满熟妇啪啪 | 亚洲综合AV色婷婷国产野外| 欧美日韩一区二区三区人妻| 丰满少妇张开双腿无码AV| 亚洲丁香婷婷久久一区二区| 男女作爱在线播放免费网站| 国产ZLJZLJZLJZLJ| 亚洲在AV人极品无码网站| 日本久久久WWW成人免费毛片丨| 国产午夜福利100集发布| 再深点灬舒服灬太大了添视频软件 | 拔萝卜日本视频在线观看免费| 性色A∨人人爽网站HD| 免费无码AV污污污在线观看| 给老子叫 老子喜欢听| 亚洲性爱一区二区| 日本无人区一线影视| 狠狠88综合久久久久综合网| AV大片在线无码永久免费网址| 无码字幕AV一区二区三区| 蜜芽亚洲AV无码精品国产| 国产精品18久久久久久vr|