成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript30秒, 從入門到放棄之Array(二)

pinecone / 1390人閱讀

摘要:循環(huán)一個數(shù)組,使用每次去刪除該數(shù)組的第一個元素直到指定方法運算結(jié)果為,返回的是剩余元素組成的數(shù)組。直到循環(huán)退出,返回此時的。對應就是,包含下界,不包含上屆。秒,從入門到放棄之二微信公眾號秒,從入門到放棄之二

difference

Returns the difference between two arrays.

Create a Set from b, then use Array.filter() on a to only keep values not contained in b.

const difference = (a, b) => { const s = new Set(b); return a.filter(x => !s.has(x)); };
// difference([1,2,3], [1,2,4]) -> [3]

返回兩個數(shù)組的不同。

創(chuàng)建一個b數(shù)組的集合,然后使用Array.filter()a數(shù)組進行過濾,過濾出不存在于數(shù)組b的元素。

?  code cat difference.js
const difference = (a, b) => {
    const s = new Set(b);
    return a.filter(x => !s.has(x));
}

console.log(difference([1, 2, 3], [1, 2, 4]));
?  code node difference.js
[ 3 ]

關(guān)鍵點是主客體,這里主體應該是第一個數(shù)組,也就是a,客體是數(shù)組b,返回的是不在主體a里的數(shù)組元素。類似于集合的a - b,不同點是a、b數(shù)組都可以有重復的元素存在,而集合不允許重復元素存在。

這邏輯是很清晰的,先把b數(shù)組轉(zhuǎn)成集合存到s中,然后去filter數(shù)組a,只要把不存在于s集合中的元素返回即可。記住filter返回的是一個數(shù)組。

differenceWith

Filters out all values from an array for which the comparator function does not return true.

Use Array.filter() and Array.find() to find the appropriate values.

const differenceWith = (arr, val, comp) => arr.filter(a => !val.find(b => comp(a, b)))
// differenceWith([1, 1.2, 1.5, 3], [1.9, 3], (a,b) => Math.round(a) == Math.round(b)) -> [1, 1.2]

從一個數(shù)組中篩選出所有不滿足指定比較方法運算結(jié)果為true的元素值的數(shù)組。

使用Array.filter()Array.find()來找出適當?shù)闹怠?/p>

?  code cat differenceWith.js
const differenceWith = (arr, val, comp) => arr.filter(a => !val.find(b => comp(a, b)));

console.log(differenceWith([1, 1.2, 1.5, 3], [1.9, 3], (a,b) => Math.round(a) == Math.round(b)));
?  code node differenceWith.js
[ 1, 1.2 ]

difference類似,主客體還是第一個數(shù)組arr。

我們可以先把意思進行拆分。

comp運行結(jié)果為true

數(shù)組val.find()去尋找comp(a, b)(a是arr元素,b是val元素)運行結(jié)果為true的值

arr不要上面第2點中運行結(jié)果為true的值

通俗點就是說去遍歷數(shù)組arr的所有元素,然后在數(shù)組val里尋找comp運算結(jié)果不為true的值。因為val.find()方法如果找到就返回該值,否則返回undefined,此時!val.find()就是truearr.filter()正是需要這樣運算結(jié)果的值。

distinctValuesOfArray

Returns all the distinct values of an array.

Use ES6 Set and the ...rest operator to discard all duplicated values.

const distinctValuesOfArray = arr => [...new Set(arr)];
// distinctValuesOfArray([1,2,2,3,4,4,5]) -> [1,2,3,4,5]

返回數(shù)組去重結(jié)果。

使用ES6的集合SetES6的擴展運算符把重復的元素排除掉。

?  code cat distinctValuesOfArray.js
const distinctValuesOfArray = arr => [...new Set(arr)];

console.log(distinctValuesOfArray([1, 2, 2, 3, 4, 4, 5]));
?  code node distinctValuesOfArray.js
[ 1, 2, 3, 4, 5 ]

實際上ES6的集合Set干的事,沒啥可說。

dropElements

Removes elements in an array until the passed function returns true. Returns the remaining elements in the array.

Loop through the array, using Array.slice() to drop the first element of the array until the returned value from the function is true. Returns the remaining elements.

const dropElements = (arr, func) => {
  while (arr.length > 0 && !func(arr[0])) arr = arr.slice(1);
  return arr;
};
// dropElements([1, 2, 3, 4], n => n >= 3) -> [3,4]

剔除掉數(shù)組元素直到指定方法運算結(jié)果第一次為true為止。

循環(huán)一個數(shù)組,使用Array.slice每次去刪除該數(shù)組的第一個元素直到指定方法運算結(jié)果為true,返回的是剩余元素組成的數(shù)組。

?  code cat dropElements.js
const dropElements = (arr, func) => {
    while (arr.length > 0 && !func(arr[0])) arr = arr.slice(1);
    return arr;
};

console.log(dropElements([1, 2, 3, 4], n => n >= 3));
?  code node dropElements.js
[ 3, 4 ]

這里用while進行循環(huán),循環(huán)條件是數(shù)組的長度大于0并且數(shù)組的第一個元素按照指定方法運行結(jié)果為false,如果滿足條件,使用arr.slice(1)arr第一個元素刪除掉。直到while循環(huán)退出,返回此時的arr。

這里的邊界條件是數(shù)組長度為0,這時候就不進入while循環(huán),直接返回空數(shù)組。

dropRight

Returns a new array with n elements removed from the right.

Use Array.slice() to slice the remove the specified number of elements from the right.

const dropRight = (arr, n = 1) => arr.slice(0, -n);
//dropRight([1,2,3]) -> [1,2]
//dropRight([1,2,3], 2) -> [1]
//dropRight([1,2,3], 42) -> []

返回數(shù)組從右邊開始剔除掉n個元素后的數(shù)組。

使用Array.slice()切掉從右邊開始計算的指定數(shù)目的元素。

?  code cat dropRight.js
const dropRight = (arr, n = 1) => arr.slice(0, -n);

console.log(dropRight([1, 2, 3]));
console.log(dropRight([1, 2, 3], 2));
console.log(dropRight([1, 2, 3], 42));
?  code node dropRight.js
[ 1, 2 ]
[ 1 ]
[]

n的默認值是1,所以不傳第二個參數(shù)的時候會刪掉數(shù)組的最后一個元素。

-n不好理解嗎?變換一下就好了arr.slice(0, -n)arr.slice(0, arr.length + (-n))是一樣的。

slice(m, n)對應就是[m, n),包含下界,不包含上屆。

everyNth

Returns every nth element in an array.

Use Array.filter() to create a new array that contains every nth element of a given array.

const everyNth = (arr, nth) => arr.filter((e, i) => i % nth === nth - 1);
// everyNth([1,2,3,4,5,6], 2) -> [ 2, 4, 6 ]

返回一個新的數(shù)組,數(shù)組包含每nth的元素,即nth倍數(shù)的元素。

使用Array.filter()創(chuàng)建一個包含nth倍數(shù)元素的新數(shù)組。

?  code cat everyNth.js
const everyNth = (arr, nth) => arr.filter((e, i) => i % nth === nth - 1);

console.log(everyNth([1, 2, 3, 4, 5, 6], 2));
?  code node everyNth.js
[ 2, 4, 6 ]

判斷是否nth倍數(shù)只需要知道該元素的索引加1后能不能被nth整除即可。

如果是我的話我會這么寫(e, i) => (i + 1) % nth === 0,可能這樣比較符合我的思維習慣。

filterNonUnique

Filters out the non-unique values in an array.

Use Array.filter() for an array containing only the unique values.

const filterNonUnique = arr => arr.filter(i => arr.indexOf(i) === arr.lastIndexOf(i));
// filterNonUnique([1,2,2,3,4,4,5]) -> [1,3,5]

過濾掉不唯一元素后返回的數(shù)組。

使用Array.filter()去篩選滿足數(shù)組元素唯一性的元素。

?  code cat filterNonUnique.js
const filterNonUnique = arr => arr.filter(i => arr.indexOf(i) === arr.lastIndexOf(i));

console.log(filterNonUnique([1, 2, 2, 3, 4, 4, 5]));
?  code node filterNonUnique.js
[ 1, 3, 5 ]

方法用得很巧,一個數(shù)如果出現(xiàn)在一個數(shù)組超過一次,那么該數(shù)在數(shù)組中的左索引indexOf(從左邊數(shù)第一次出現(xiàn)該數(shù)的索引)和右索引lastIndexOf(從右邊數(shù)第一次出現(xiàn)該數(shù)的索引)一定不相等。

反過來說左索引等于右索引,該數(shù)在數(shù)組中只出現(xiàn)一次,滿足唯一性。

這里和distinctValuesOfArray的區(qū)別是,distinctValuesOfArray刪掉了重復的元素,只留一個;filterNonUnique刪掉了所有重復元素,一個不留。

flatten

Flattens an array.

Use a new array and concatenate it with the spread input array causing a shallow denesting of any contained arrays.

const flatten = arr => [ ].concat( ...arr );
// flatten([1,[2],3,4]) -> [1,2,3,4]

攤平一個數(shù)組。

Array.concat()、空數(shù)組[]ES6的擴展運算符來攤平一個數(shù)組。這里是淺度攤平,即只攤平一層。

?  code cat flatten.js
const flatten = arr => [].concat(...arr);

console.log(flatten([1, [2], 3, 4]));
console.log(flatten([1, [[2], 5], 3, 4]));
?  code node flatten.js
[ 1, 2, 3, 4 ]
[ 1, [ 2 ], 5, 3, 4 ]

主要是用[]ES6的擴展運算符arr運算結(jié)果concat連接起來。

deepFlatten的區(qū)別就是flatten只攤平一層,deepFlatten深度攤平。

個人翻譯水平有限,歡迎大家在issues上批評指正。JavaScript30秒, 從入門到放棄之Array(二)
微信公眾號:JavaScript30秒, 從入門到放棄之Array(二)

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90425.html

相關(guān)文章

  • JavaScript30, 入門放棄Array(五)

    摘要:原文地址秒,從入門到放棄之五博客地址秒,從入門到放棄之五水平有限,歡迎批評指正從給定的數(shù)組中隨機選出指定個數(shù)的數(shù)組元素。否則判斷數(shù)組元素是否大于或者等于指定元素,尋找過程與前邊類似。 原文地址:JavaScript30秒, 從入門到放棄之Array(五)博客地址:JavaScript30秒, 從入門到放棄之Array(五) 水平有限,歡迎批評指正 sampleSize Gets n...

    dunizb 評論0 收藏0
  • JavaScript30, 入門放棄Array(四)

    摘要:使用把指定運算結(jié)果為的數(shù)組元素添加到二維數(shù)組的第一個數(shù)組中,運算結(jié)果為的數(shù)組元素添加到二維數(shù)組的第二個數(shù)組中。所以改成了,它是不改變數(shù)組元素的,沒有副作用,不干擾后續(xù)。方法將剩余的所有數(shù)組元素以的方式返回結(jié)果數(shù)組。 原文地址:JavaScript30秒, 從入門到放棄之Array(四)博客地址:JavaScript30秒, 從入門到放棄之Array(四) 水平有限,歡迎批評指正 ma...

    wuaiqiu 評論0 收藏0
  • JavaScript30入門放棄Array(三)

    摘要:否則,直接循環(huán)去拼接該值返回按照指定的方法對數(shù)組元素進行分組歸類。使用創(chuàng)建一個對象,對象的鍵是生成的結(jié)果,值是符合該鍵的所有數(shù)組元素組成的數(shù)組。微信公眾號秒,從入門到放棄之三 原文鏈接:JavaScript30秒, 從入門到放棄之Array(三)水平有限,歡迎批評指正 flattenDepth Flattens an array up to the specified depth....

    FrancisSoung 評論0 收藏0
  • JavaScript30, 入門放棄Array(六)

    摘要:從數(shù)組索引為開始刪除元素,直到對數(shù)組元素運用指定方法為為止。對兩個數(shù)組的元素分別調(diào)用指定方法后,返回以運行結(jié)果為判定基準的并集,并集是原始數(shù)組元素的并集而不是運行結(jié)果的并集。 原文地址:JavaScript30秒, 從入門到放棄之Array(六)博客地址:JavaScript30秒, 從入門到放棄之Array(六) 水平有限,歡迎批評指正 tail Returns all elem...

    Freeman 評論0 收藏0
  • JavaScript30, 入門放棄Array(七)

    摘要:地址秒,從入門到放棄之七博客地址秒,從入門到放棄之七水平有限,歡迎批評指正剔除掉數(shù)組中所有存在于所指定的元素們的項。使用,和來創(chuàng)建由兩個數(shù)組元素拼接而成的所有可能對并將它們存在一個數(shù)組中的數(shù)組。 GitHub地址:JavaScript30秒, 從入門到放棄之Array(七)博客地址:JavaScript30秒, 從入門到放棄之Array(七) 水平有限,歡迎批評指正 without ...

    Cciradih 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<