摘要:循環(huán)一個數(shù)組,使用每次去刪除該數(shù)組的第一個元素直到指定方法運(yùn)算結(jié)果為,返回的是剩余元素組成的數(shù)組。直到循環(huán)退出,返回此時的。對應(yīng)就是,包含下界,不包含上屆。秒,從入門到放棄之二微信公眾號秒,從入門到放棄之二
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ù)組進(jìn)行過濾,過濾出不存在于數(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)鍵點(diǎn)是主客體,這里主體應(yīng)該是第一個數(shù)組,也就是a,客體是數(shù)組b,返回的是不在主體a里的數(shù)組元素。類似于集合的a - b,不同點(diǎn)是a、b數(shù)組都可以有重復(fù)的元素存在,而集合不允許重復(fù)元素存在。
這邏輯是很清晰的,先把b數(shù)組轉(zhuǎn)成集合存到s中,然后去filter數(shù)組a,只要把不存在于s集合中的元素返回即可。記住filter返回的是一個數(shù)組。
differenceWithFilters 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ù)組中篩選出所有不滿足指定比較方法運(yùn)算結(jié)果為true的元素值的數(shù)組。
使用Array.filter()和Array.find()來找出適當(dāng)?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。
我們可以先把意思進(jìn)行拆分。
comp運(yùn)行結(jié)果為true
數(shù)組val.find()去尋找comp(a, b)(a是arr元素,b是val元素)運(yùn)行結(jié)果為true的值
arr不要上面第2點(diǎn)中運(yùn)行結(jié)果為true的值
通俗點(diǎn)就是說去遍歷數(shù)組arr的所有元素,然后在數(shù)組val里尋找comp運(yùn)算結(jié)果不為true的值。因?yàn)?b>val.find()方法如果找到就返回該值,否則返回undefined,此時!val.find()就是true,arr.filter()正是需要這樣運(yùn)算結(jié)果的值。
distinctValuesOfArrayReturns 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的集合Set和ES6的擴(kuò)展運(yùn)算符…把重復(fù)的元素排除掉。
? 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 ]
實(shí)際上ES6的集合Set干的事,沒啥可說。
dropElementsRemoves 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ù)組元素直到指定方法運(yùn)算結(jié)果第一次為true為止。
循環(huán)一個數(shù)組,使用Array.slice每次去刪除該數(shù)組的第一個元素直到指定方法運(yùn)算結(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進(jìn)行循環(huán),循環(huán)條件是數(shù)組的長度大于0并且數(shù)組的第一個元素按照指定方法運(yùn)行結(jié)果為false,如果滿足條件,使用arr.slice(1)將arr第一個元素刪除掉。直到while循環(huán)退出,返回此時的arr。
這里的邊界條件是數(shù)組長度為0,這時候就不進(jìn)入while循環(huán),直接返回空數(shù)組。
dropRightReturns 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的默認(rèn)值是1,所以不傳第二個參數(shù)的時候會刪掉數(shù)組的最后一個元素。
-n不好理解嗎?變換一下就好了arr.slice(0, -n)跟arr.slice(0, arr.length + (-n))是一樣的。
slice(m, n)對應(yīng)就是[m, n),包含下界,不包含上屆。
everyNthReturns 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,可能這樣比較符合我的思維習(xí)慣。
filterNonUniqueFilters 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刪掉了重復(fù)的元素,只留一個;filterNonUnique刪掉了所有重復(fù)元素,一個不留。
flattenFlattens 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的擴(kuò)展運(yùn)算符…來攤平一個數(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的擴(kuò)展運(yùn)算符…對arr運(yùn)算結(jié)果concat連接起來。
與deepFlatten的區(qū)別就是flatten只攤平一層,deepFlatten深度攤平。
個人翻譯水平有限,歡迎大家在issues上批評指正。JavaScript30秒, 從入門到放棄之Array(二)
微信公眾號:JavaScript30秒, 從入門到放棄之Array(二)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/90425.html
摘要:原文地址秒,從入門到放棄之五博客地址秒,從入門到放棄之五水平有限,歡迎批評指正從給定的數(shù)組中隨機(jī)選出指定個數(shù)的數(shù)組元素。否則判斷數(shù)組元素是否大于或者等于指定元素,尋找過程與前邊類似。 原文地址:JavaScript30秒, 從入門到放棄之Array(五)博客地址:JavaScript30秒, 從入門到放棄之Array(五) 水平有限,歡迎批評指正 sampleSize Gets n...
摘要:使用把指定運(yùn)算結(jié)果為的數(shù)組元素添加到二維數(shù)組的第一個數(shù)組中,運(yùn)算結(jié)果為的數(shù)組元素添加到二維數(shù)組的第二個數(shù)組中。所以改成了,它是不改變數(shù)組元素的,沒有副作用,不干擾后續(xù)。方法將剩余的所有數(shù)組元素以的方式返回結(jié)果數(shù)組。 原文地址:JavaScript30秒, 從入門到放棄之Array(四)博客地址:JavaScript30秒, 從入門到放棄之Array(四) 水平有限,歡迎批評指正 ma...
摘要:否則,直接循環(huán)去拼接該值返回按照指定的方法對數(shù)組元素進(jìn)行分組歸類。使用創(chuàng)建一個對象,對象的鍵是生成的結(jié)果,值是符合該鍵的所有數(shù)組元素組成的數(shù)組。微信公眾號秒,從入門到放棄之三 原文鏈接:JavaScript30秒, 從入門到放棄之Array(三)水平有限,歡迎批評指正 flattenDepth Flattens an array up to the specified depth....
摘要:從數(shù)組索引為開始刪除元素,直到對數(shù)組元素運(yùn)用指定方法為為止。對兩個數(shù)組的元素分別調(diào)用指定方法后,返回以運(yùn)行結(jié)果為判定基準(zhǔn)的并集,并集是原始數(shù)組元素的并集而不是運(yùn)行結(jié)果的并集。 原文地址:JavaScript30秒, 從入門到放棄之Array(六)博客地址:JavaScript30秒, 從入門到放棄之Array(六) 水平有限,歡迎批評指正 tail Returns all elem...
摘要:地址秒,從入門到放棄之七博客地址秒,從入門到放棄之七水平有限,歡迎批評指正剔除掉數(shù)組中所有存在于所指定的元素們的項(xiàng)。使用,和來創(chuàng)建由兩個數(shù)組元素拼接而成的所有可能對并將它們存在一個數(shù)組中的數(shù)組。 GitHub地址:JavaScript30秒, 從入門到放棄之Array(七)博客地址:JavaScript30秒, 從入門到放棄之Array(七) 水平有限,歡迎批評指正 without ...
閱讀 2032·2021-11-08 13:14
閱讀 2940·2021-10-18 13:34
閱讀 2028·2021-09-23 11:21
閱讀 3591·2019-08-30 15:54
閱讀 1760·2019-08-30 15:54
閱讀 2930·2019-08-29 15:33
閱讀 2581·2019-08-29 14:01
閱讀 1948·2019-08-29 13:52