亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

不得不知的ES6小技巧

2024-05-06 16:45:25
字體:
來源:轉載
供稿:網友

如果你還知道其他一些小技巧,歡迎留言~ 很高興把它們補充進來。

1. 強制要求參數

ES6提供了默認參數值機制,允許你為參數設置默認值,防止在函數被調用時沒有傳入這些參數。

在下面的例子中,我們寫了一個required()函數作為參數a和b的默認值。這意味著如果a或b其中有一個參數沒有在調用時傳值,會默認required()函數,然后拋出錯誤。

const required = () => {throw new Error('Missing parameter')};const add = (a = required(), b = required()) => a + b;add(1, 2) //3add(1) // Error: Missing parameter.

2. 強大的reduce

數組的reduce方法用途很廣。它一般被用來把數組中每一項規約到單個值。但是你可以利用它做更多的事。

2.1 使用reduce同時實現map和filter

假設現在有一個數列,你希望更新它的每一項(map的功能)然后篩選出一部分(filter的功能)。如果是先使用map然后filter的話,你需要遍歷這個數組兩次。

在下面的代碼中,我們將數列中的值翻倍,然后挑選出那些大于50的數。有注意到我們是如何非常高效地使用reduce來同時完成map和filter方法的嗎?

const numbers = [10, 20, 30, 40];const doubledOver50 = numbers.reduce((finalList, num) => {  num = num * 2;   if (num > 50) {  finalList.push(num); }  return finalList;}, []);doubledOver50; // [60, 80]

2.2 使用reduce取代map和filter

如果你認真閱讀了上面的代碼,你應該能理解reduce是可以取代map和filter的。

2.3 使用reduce匹配圓括號

reduce的另外一個用途是能夠匹配給定字符串中的圓括號。對于一個含有圓括號的字符串,我們需要知道(和)的數量是否一致,并且(是否出現在)之前。

下面的代碼中我們使用reduce可以輕松地解決這個問題。我們只需要先聲明一個counter變量,初值為0。在遇到(時counter加一,遇到)時counter減一。如果左右括號數目匹配,那最終結果為0。

//Returns 0 if balanced.const isParensBalanced = (str) => { return str.split('').reduce((counter, char) => {  if(counter < 0) { //matched ")" before "("   return counter;  } else if(char === '(') {   return ++counter;  } else if(char === ')') {    return --counter;  } else { //matched some other char   return counter;  }   }, 0); //<-- starting value of the counter}isParensBalanced('(())') // 0 <-- balancedisParensBalanced('(asdfds)') //0 <-- balancedisParensBalanced('(()') // 1 <-- not balancedisParensBalanced(')(') // -1 <-- not balanced

2.4 統計數組中相同項的個數

很多時候,你希望統計數組中重復出現項的個數然后用一個對象表示。那么你可以使用reduce方法處理這個數組。

下面的代碼將統計每一種車的數目然后把總數用一個對象表示。

var cars = ['BMW','Benz', 'Benz', 'Tesla', 'BMW', 'Toyota'];var carsObj = cars.reduce(function (obj, name) {   obj[name] = obj[name] ? ++obj[name] : 1; return obj;}, {});carsObj; // => { BMW: 2, Benz: 2, Tesla: 1, Toyota: 1 }

reduce的其他用處實在是太多了,建議閱讀MDN的相關代碼示例。

3. 對象解構

3.1 刪除不需要的屬性

有時候你不希望保留某些對象屬性,也許是因為它們包含敏感信息或僅僅是太大了(just too big)。你可能會枚舉整個對象然后刪除它們,但實際上只需要簡單的將這些無用屬性賦值給變量,然后把想要保留的有用部分作為剩余參數就可以了。

下面的代碼里,我們希望刪除_internal和tooBig參數。我們可以把它們賦值給internal和tooBig變量,然后在cleanObject中存儲剩下的屬性以備后用。

let {_internal, tooBig, ...cleanObject} = {el1: '1', _internal:"secret", tooBig:{}, el2: '2', el3: '3'};console.log(cleanObject); // {el1: '1', el2: '2', el3: '3'}

3.2 在函數參數中解構嵌套對象

在下面的代碼中,engine是對象car中嵌套的一個對象。如果我們對engine的vin屬性感興趣,使用解構賦值可以很輕松地得到它。

var car = { model: 'bmw 2018', engine: {  v6: true,  turbo: true,  vin: 12345 }}const modelAndVIN = ({model, engine: {vin}}) => { console.log(`model: ${model} vin: ${vin}`);}modelAndVIN(car); // => model: bmw 2018 vin: 12345

3.3 合并對象

ES6帶來了擴展運算符(...)。它一般被用來解構數組,但你也可以用它處理對象。

接下來,我們使用擴展運算符來展開一個新的對象,第二個對象中的屬性值會改寫第一個對象的屬性值。比如object2的b和c就會改寫object1的同名屬性。

let object1 = { a:1, b:2,c:3 }let object2 = { b:30, c:40, d:50}let merged = {…object1, …object2} //spread and re-add into mergedconsole.log(merged) // {a:1, b:30, c:40, d:50}

4. Sets

4.1 使用Set實現數組去重

在ES6中,因為Set只存儲唯一值,所以你可以使用Set刪除重復項。

let arr = [1, 1, 2, 2, 3, 3];let deduped = [...new Set(arr)] // [1, 2, 3]

4.2 對Set使用數組方法

使用擴展運算符就可以簡單的將Set轉換為數組。所以你可以對Set使用Array的所有原生方法。

比如我們想要對下面的Set進行filter操作,獲取大于3的項。

let mySet = new Set([1,2, 3, 4, 5]);var filtered = [...mySet].filter((x) => x > 3) // [4, 5]

5. 數組解構

有時候你會將函數返回的多個值放在一個數組里。我們可以使用數組解構來獲取其中每一個值。

5.1 數值交換

let param1 = 1;let param2 = 2;//swap and assign param1 & param2 each others values[param1, param2] = [param2, param1];console.log(param1) // 2console.log(param2) // 1

5.2 接收函數返回的多個結果

在下面的代碼中,我們從/post中獲取一個帖子,然后在/comments中獲取相關評論。由于我們使用的是async/await,函數把返回值放在一個數組中。而我們使用數組解構后就可以把返回值直接賦給相應的變量。

async function getFullPost(){ return await Promise.all([   fetch('/post'),   fetch('/comments') ]);}const [post, comments] = getFullPost();

注:原文作者rajaraodv ,白吟靈譯。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美wwwxxxx| 在线日韩日本国产亚洲| 久久久久国产精品www| 中文字幕精品—区二区| 亚洲国产天堂久久国产91| 久久精品青青大伊人av| 亚洲xxxxx性| 另类少妇人与禽zozz0性伦| 欧美电影免费观看高清| 亚洲精品欧美日韩专区| 色一情一乱一区二区| 亚洲人成在线观看| 日韩成人激情在线| 日韩一区二区欧美| 久久人91精品久久久久久不卡| 国产精品日韩电影| 国产v综合v亚洲欧美久久| 久久久免费在线观看| 日韩亚洲精品视频| 国产噜噜噜噜噜久久久久久久久| 2023亚洲男人天堂| 在线播放国产一区二区三区| 国产精品美女av| 久久久久成人网| 亚洲va电影大全| 6080yy精品一区二区三区| 欧美乱人伦中文字幕在线| 欧美日韩一区二区三区在线免费观看| 美女精品视频一区| 亚洲成人国产精品| 国产精品入口夜色视频大尺度| 日韩av黄色在线观看| 日本久久久久久久| 精品亚洲aⅴ在线观看| 亚洲乱码国产乱码精品精| 国产啪精品视频网站| 国产一区av在线| 乱亲女秽乱长久久久| 日韩在线视频中文字幕| 欧美激情一区二区三区在线视频观看| 国产精品网红福利| 亚洲xxxx做受欧美| 国产97在线|亚洲| 国产日韩欧美一二三区| 在线亚洲欧美视频| 91香蕉电影院| 成人黄色免费看| 久久99青青精品免费观看| 日韩中文字幕欧美| 国产精品久久久久久网站| 2021久久精品国产99国产精品| 国产精品男人爽免费视频1| 亚洲精品一区在线观看香蕉| 国产日韩中文字幕| 欧美在线观看一区二区三区| 亚洲天天在线日亚洲洲精| 亚洲人成电影在线观看天堂色| 亚洲精品不卡在线| 日韩在线视频观看| 亚洲在线观看视频| 亚洲国产日韩欧美综合久久| 欧美激情第6页| 在线精品播放av| 亚洲精品一区二三区不卡| 久久久噜噜噜久久| 欧美午夜精品久久久久久久| 久久成人精品视频| 欧美在线视频网| 国产午夜精品全部视频在线播放| 57pao国产成人免费| 亚洲视频在线免费看| 2025国产精品视频| 日韩av在线影视| 国产v综合v亚洲欧美久久| 国产不卡精品视男人的天堂| 精品夜色国产国偷在线| 欧美丝袜美女中出在线| 亚洲精品一区二区网址| xvideos国产精品| 在线视频欧美性高潮| 亚洲人成网7777777国产| 欧美日韩福利视频| 国产成人精品在线观看| 欧美在线欧美在线| 成人啪啪免费看| 亚洲午夜精品久久久久久性色| 久久免费视频这里只有精品| 日产精品久久久一区二区福利| 亚洲美女视频网站| 成人网在线视频| 久久精品国产久精国产一老狼| 国产精品免费电影| 亚洲精品色婷婷福利天堂| 欧美xxxwww| 亚洲精品v天堂中文字幕| 久久亚洲精品视频| 亚洲欧美日韩中文视频| 一区二区三区黄色| 欧美裸体男粗大视频在线观看| 色青青草原桃花久久综合| 久久免费视频网站| 午夜精品一区二区三区av| 精品成人乱色一区二区| 国产噜噜噜噜噜久久久久久久久| 26uuu亚洲国产精品| 色99之美女主播在线视频| 色偷偷888欧美精品久久久| 久久久亚洲影院你懂的| 国内外成人免费激情在线视频网站| 欧美视频免费在线观看| 欧美成人性生活| 亚洲图片欧美午夜| 久久精品夜夜夜夜夜久久| 亚洲欧美国产精品专区久久| 深夜成人在线观看| 一区二区三区高清国产| 欧美激情影音先锋| 爱福利视频一区| 欧美激情a∨在线视频播放| 国产亚洲成av人片在线观看桃| 亚洲网站在线观看| 亚洲欧美成人一区二区在线电影| 中文字幕亚洲国产| 日韩视频在线观看免费| 国产91在线高潮白浆在线观看| 成人免费直播live| 欧美中文在线观看| 国产成人精品在线观看| 在线a欧美视频| 亚洲韩国日本中文字幕| 日韩欧美精品在线观看| 欧美性猛交99久久久久99按摩| 色综合天天综合网国产成人网| 美女性感视频久久久| 一区二区三区四区视频| 欧美巨乳在线观看| 欧美整片在线观看| 日韩精品免费一线在线观看| 欧美精品18videos性欧| 青青草原一区二区| 日韩av在线免播放器| 色综合久久中文字幕综合网小说| 亚洲香蕉av在线一区二区三区| www.亚洲一区| 久久国产精品网站| 92看片淫黄大片欧美看国产片| 国产在线一区二区三区| 日韩亚洲第一页| 亚洲视频自拍偷拍| 国产精品99久久久久久www| 国产成人aa精品一区在线播放| 欧美成人免费在线视频| 美女啪啪无遮挡免费久久网站| 亚洲色在线视频| 国产精品在线看| 疯狂做受xxxx欧美肥白少妇| 成人精品福利视频| 国产精品美女久久久久av超清| 亚洲电影中文字幕| 日日噜噜噜夜夜爽亚洲精品| 亚洲精品小视频| 亚洲精品按摩视频| 欧美精品午夜视频| 日韩高清电影免费观看完整|