偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

十個前端開發(fā)人員必須知道的關(guān)于“[].reduce”的進(jìn)階技巧

開發(fā) 前端
作為一個前端開發(fā)者,一定會大量使用reduce函數(shù),它是一個強(qiáng)大而有用的數(shù)組API,但是,今天我想給大家分享10個關(guān)于它的進(jìn)階技巧和竅門,加油!

作為一個前端開發(fā)者,一定會大量使用reduce函數(shù),它是一個強(qiáng)大而有用的數(shù)組API,但是,今天我想給大家分享10個關(guān)于它的進(jìn)階技巧和竅門,加油!

1.作為加法器和累加器

使用“reduce”,我們可以輕松實現(xiàn)多個數(shù)相加或累加的功能。

// adderconst sum = (...nums) =>  return nums.reduce((sum, num) =>};console.log(sum(1, 2, 3, 4, 10)); // 20// accumulatorconst accumulator = (...nums) =>  return nums.reduce((acc, num) =>};console.log(accumulator(1, 2, 3)); // 6

2.計算一個數(shù)組的最大值和最小值

有多少種方法可以得到數(shù)組的最大值或最小值?

1).使用 Math.max 和 Math.min

我們不得不承認(rèn),使用 Math 的 API 是最簡單的方法。

const array = [-1, 10, 6, 5];const max = Math.max(...array); // 10const min = Math.min(...array); // -1

2).使用減少

是的,只需一行代碼,你就可以實現(xiàn)與 Math 的 API 相同的效果。

const array = [-1, 10, 6, 5];const max = array.reduce((max, num) => (max > num ? max : num));const min = array.reduce((min, num) => (min < num ? min : num));

3).格式化搜索參數(shù)

獲取鏈接上的搜索參數(shù)是我們經(jīng)常要處理的事情。如何解析它們?

例如:

// url https://qianlongo.github.io/vue-demos/dist/index.html?name=fatfish&age=100#/home// format the search parameters{  "name": "fatfish",  "age": "100"}

1).正常方式

這是大多數(shù)人使用它的方式。

const parseQuery = ()  const search = window.location.search;  let query = {};  search    .slice(1)    .split("&")(it) =>      const [key, value] = it.split("=");      query[key] = decodeURIComponent(value);    });  return query;};

2).使用reduce

Reduce 實際上可以做到這一點,而且看起來更簡單。

const parseQuery = ()  const search = window.location.search;  return search    .replace(/(^\?)|(&$)/g, "")    .split("&")(query, it) =>      const [key, value] = it.split("=");      query[key] = decodeURIComponent(value);      return query;    }, {});};

它是如何工作的?

/ url https://qianlongo.github.io/vue-demos/dist/index.html?name=fatfish&age=100#/home// 1. First get the search parameterconst search = window.location.search; // ?name=fatfish&age=100// 2. Remove the beginning "?" or ending "&".search.replace(/(^\?)|(&$)/g, "");// ?name=fatfish&age=100 => name=fatfish&age=100// 3. Use reduce to collect parameters// ...

4.反序列化搜索參數(shù)

當(dāng)我們要跳轉(zhuǎn)到某個鏈接并為其添加一些搜索參數(shù)時,手動拼接的方式不是很方便。

如果要串聯(lián)的參數(shù)很多,那將是一場災(zāi)難。

const searchObj = {name: "fatfish",age: 100,  // ...};const link = `https://medium.com/?name=${searchObj.name}&age=${searchObj.age}`;// https://medium.com/?name=fatfish&age=100

幸運的是,“reduce”可以幫助我們輕松解決這個問題。

const stringifySearch = (search = {}) =>  return Object.entries(search)    .reduce((t, v) => `${t}${v[0]}=${encodeURIComponent(v[1])}&`,      Object.keys(search).length ? "?" : ""    )    .replace(/&$/, "");};const search = stringifySearch({name: "fatfish",age: 100,});const link = `https://medium.com/${search}`;console.log(link); // https://medium.com/?name=fatfish&age=100

5. 展平多層嵌套數(shù)組

你知道如何展平多層嵌套數(shù)組嗎?

const array = [1, [2, [3, [4, [5]]]]];// expected output [ 1, 2, 3, 4, 5 ]const flatArray = array.flat(Infinity); // [1, 2, 3, 4, 5]

“flat”是一個非常強(qiáng)大的API。而使用reduce可以實現(xiàn)和flat一樣的功能

const flat = (array) => {  return array.reduce(    (acc, it) => acc.concat(Array.isArray(it) ? flat(it) : it),    []  );};const array = [1, [2, [3, [4, [5]]]]];const flatArray = flat(array); // [1, 2, 3, 4, 5]

6.模擬平面特征的功能

雖然,我們已經(jīng)實現(xiàn)了扁平化深度嵌套數(shù)組的功能,但是,如何才能完全實現(xiàn)扁平化的功能呢?

// Expand one layer by defaultArray.prototype.flat2 = function (n = 1) {  const len = this.length  let count = 0  let current = this  if (!len || n === 0) {    return current  }  // Confirm whether there are array items in current  const hasArray = () current.some((it) => Array.isArray(it))  // Expand one layer after each cycle  while (count++ < n && hasArray()) {(result, it) =>      result = result.concat(it)      return result    }, [])  }  return current}const array = [ 1, [ 2, [ 3, [ 4, [ 5 ] ] ] ] ]// Expand one layerconsole.log(array.flat()) // [ 1, 2, [ 3, [ 4, [ 5 ] ] ] ] console.log(array.flat2()) // [ 1, 2, [ 3, [ 4, [ 5 ] ] ] ] // Expand allconsole.log(array.flat(Infinity))console.log(array.flat2(Infinity))

太好了,我們做到了。

7. 保持?jǐn)?shù)組唯一

reduce 也很容易保持?jǐn)?shù)組的唯一性。

const array = [ 1, 2, 1, 2, -1, 10, 11 ]const uniqueArray1 = [ ...new Set(array) ]const uniqueArray2 = array.reduce((acc, it) => acc.includes(it) ? acc : [ ...acc, it ], [])

8.統(tǒng)計數(shù)組成員的個數(shù)

如何計算數(shù)組中每個成員的個數(shù)?

為什么使用map而不是boject?

const count = (array) =>  return array.reduce((acc, it) => (acc.set(it, (acc.get(it) || 0) + 1), acc), new Map())}const array = [ 1, 2, 1, 2, -1, 0, '0', 10, '10' ]console.log(count(array))

9.獲取一個對象的多個屬性

現(xiàn)在,我們來看看在工作中會遇到的一個場景。

// There is an object with many propertiesconst obj = {  a: 1,  b: 2,  c: 3,  d: 4,  e: 5  // ...}// We just want to get some properties above it to create a new objectconst newObj = {  a: obj.a,  b: obj.b,  c: obj.c,  d: obj.d  // ...}// Do you think this is too inefficient?

使用reduce來解決它。

const getObjectKeys = (obj = {}, keys = []) =>  return Object.keys(obj).reduce((acc, key) =>}const obj = {a: 1,b: 2,c: 3,d: 4,e: 5  // ...}const newObj = getObjectKeys(obj, [ 'a', 'b', 'c', 'd' ])console.log(newObj)

10.反轉(zhuǎn)字符串

const reverseString = (string) =>  return string.split("").reduceRight((acc, s) =>}const string = 'fatfish'console.log(reverseString(string)) // hsiftaf

寫在最后

以上就是我跟你分享的10個關(guān)于reduce的知識技巧,希望你你能從中學(xué)到一些新的東西,也希望對你有用,如果你覺得有幫助我話,請點贊我,關(guān)注我,并將這篇文章與你的開發(fā)者朋友一起來分享它。

最后,感謝你的閱讀,編程愉快。

責(zé)任編輯:華軒 來源: web前端開發(fā)
相關(guān)推薦

2022-06-08 10:42:34

ReduceJavaScript技巧

2023-05-11 16:29:39

Javascript開發(fā)前端

2018-04-08 10:08:43

開發(fā)人員工具

2009-06-25 09:04:22

.NET開發(fā)人員

2019-11-25 09:41:28

開發(fā)者技能工具

2020-04-20 09:57:00

開發(fā)工具技術(shù)

2024-11-04 14:18:32

JavaScript編程語言開發(fā)

2023-02-27 15:44:17

Java開發(fā)技巧

2023-12-12 17:46:33

系統(tǒng)kswapd0內(nèi)核

2022-03-14 14:11:22

Java開發(fā)編程語言

2023-04-11 15:22:06

JavaScript開發(fā)前端

2024-10-21 13:15:03

2021-11-02 08:54:10

開發(fā)編程測試

2021-11-06 23:07:47

開發(fā)網(wǎng)站編程

2023-02-02 08:00:00

SQLJava開發(fā)

2017-10-24 11:59:41

JavaScript

2017-12-25 16:15:49

前端JavaScript簡寫技巧

2023-02-26 18:43:05

SQL工具數(shù)據(jù)庫

2022-12-01 10:05:19

2020-06-09 07:57:47

前端開發(fā)代碼
點贊
收藏

51CTO技術(shù)棧公眾號