国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

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

Freeman / 2725人閱讀

摘要:從數組索引為開始刪除元素,直到對數組元素運用指定方法為為止。對兩個數組的元素分別調用指定方法后,返回以運行結果為判定基準的并集,并集是原始數組元素的并集而不是運行結果的并集。

原文地址:JavaScript30秒, 從入門到放棄之Array(六)

博客地址:JavaScript30秒, 從入門到放棄之Array(六)

水平有限,歡迎批評指正

tail

Returns all elements in an array except for the first one.

Return Array.slice(1) if the array"s length is more than 1, otherwise, return the whole array.

const tail = arr => (arr.length > 1 ? arr.slice(1) : arr);

返回除了數組第一個元素以外的所有元素。

如果數組長度大于1,則用Array.slice(1)返回;否則返回整個數組。

?  code cat tail.js
const tail = arr => (arr.length > 1 ? arr.slice(1) : arr);

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

Returns an array with n elements removed from the beginning.

Use Array.slice() to create a slice of the array with n elements taken from the beginning.

const take = (arr, n = 1) => arr.slice(0, n);

返回一個由數組的前n個元素組成的新數組。

Array.slice()創建一個新的數組,數組元素由指定數組的前n個元素組成。

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

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

n可以指定為0,即一個也不取出。省略則n = 1

takeRight

Returns an array with n elements removed from the end.

Use Array.slice() to create a slice of the array with n elements taken from the end.

const takeRight = (arr, n = 1) => arr.slice(arr.length - n, arr.length);

返回一個由數組的后n個元素組成的新數組。

Array.slice()創建一個新的數組,數組元素由指定數組的后n個元素組成。

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

console.log(takeRight([1, 2, 3], 2));
console.log(takeRight([1, 2, 3]));

?  code node takeRight.js
[ 2, 3 ]
[ 3 ]

拿數組后n個元素只需從數組長度減去n的位置開始取到結尾就可以了,slice第二個參數是可以省略的,因為是取到最后一個元素。

takeRightWhile

Removes elements from the end of an array until the passed function returns true. Returns the removed elements.

Loop through the array, using a for...of loop over Array.keys() until the returned value from the function is true. Return the removed elements, using Array.reverse() and Array.slice().

const takeRightWhile = (arr, func) => {
  for (let i of arr.reverse().keys())
    if (func(arr[i])) return arr.reverse().slice(arr.length - i, arr.length);
  return arr;
};

從數組尾部開始刪除元素,直到對數組元素運用指定方法fntrue為止。同時返回被刪除的元素。

循環數組,使用for…of循環Array.keys()直到對數組元素調用指定方法返回true為止。最后返回刪除的所有元素,過程中結合了Array.reverse()Array.slice()

?  code cat takeRightWhile.js
const takeRightWhile = (arr, func) => {
  for (let i of arr.reverse().keys())
    if(func(arr[i]))
      return arr.reverse().slice(arr.length - i, arr.length);
    return arr;
};

console.log(takeRightWhile([1, 2, 3, 4], n => n < 3));

?  code node takeRightWhile.js
[ 3, 4 ]
for (let i of arr.reverse().keys())

循環數組arrkey值,即索引,因為是reverse(),所以是反向循環。如一個數組有五個元素,那么i就是4->3->2->1->0這樣的順序。

if(func(arr[i]))
  return arr.reverse().slice(arr.length - i, arr.length);

對數組元素arr[i]調用func,若真,此時的i就是順數的第一個該刪除的元素的索引,要刪除的元素就是從此直到數組結尾為止;即arr.reverse().slice(arr.length - i, arr.length)包含的索引元素。

return arr;

如果前面的整個遍歷過程中func(arr[i])都不為true的話,那就返回原數組,合情合理。

takeWhile

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

Loop through the array, using a for...of loop over Array.keys() until the returned value from the function is true. Return the removed elements, using Array.slice().

const takeWhile = (arr, func) => {
 for (let i of arr.keys()) if (func(arr[i])) return arr.slice(0, i);
 return arr;
};

從數組索引為0開始刪除元素,直到對數組元素運用指定方法fntrue為止。同時返回被刪除的元素。

?  code cat takeWhile.js
const takeWhile = (arr, fn) => {
  for (let i of arr.keys()) if(fn(arr[i])) return arr.slice(0, i);
  return arr;
};

console.log(takeWhile([1, 2, 3, 4], n => n >= 3));

?  code node takeWhile.js
[ 1, 2 ]

takeRightWhile正好相反,而且還更容易理解。沒什么可說的了。

union

Returns every element that exists in any of the two arrays once.

Create a Set with all values of a and b and convert to an array.

const union = (a, b) => Array.from(new Set([...a, ...b]));

返回兩個數組的并集(像集合的并集一樣,不包含重復元素)。

創建一個以ab數組為元素的集合并把它轉化成數組。

?  code cat union.js
const union = (a, b) => Array.from(new Set([...a, ...b]));

console.log(union([1, 2, 3], [4, 3, 2]));

?  code node union.js
[ 1, 2, 3, 4 ]

我自己寫的如下:

const union = (a, b) => [...new Set([...a, ...b])];

直接用ES6擴展運算符也能達到效果。

原理太簡單,創建ab數組的集合自然把他們兩者的重復元素去掉了。

unionBy

Returns every element that exists in any of the two arrays once, after applying the provided function to each array element of both.

Create a Set by applying all fn to all values of a. Create a Set from a and all elements in b whose value, after applying fn does not match a value in the previously created set. Return the last set converted to an array.

const unionBy = (a, b, fn) => {
  const s = new Set(a.map(v => fn(v)));
  return Array.from(new Set([...a, ...b.filter(x => !s.has(fn(x)))]));
};

對兩個數組的元素分別調用指定方法后,返回以運行結果為判定基準的并集,并集是原始數組元素的并集而不是運行結果的并集。

創建一個a數組調用fn后的集合a1。再創建一個以數組a和對數組b進行過濾所有存在于集合a1中的元素后所剩余元素組成的數組為基準的集合。并把該集合轉換成最終的數組。

?  code cat unionBy.js
const unionBy = (a, b, fn) => {
  const s = new Set(a.map(v => fn(v)));

  return Array.from(new Set([...a, ...b.filter(v => !s.has(fn(v)))]));
};

console.log(unionBy([2.1], [1.2, 2.3], Math.floor));

?  code node unionBy.js
[ 2.1, 1.2 ]
const s = new Set(a.map(v => fn(v)));

首先得創建其中一個數組的集合s

b.filter(v => !s.has(fn(v)))

這里就是把b數組中所有存在于a調用fn后生成的集合s的元素都刪除掉。這樣剩下的所有元素和a數組再進行集合運算后再轉換成數組。就是我們所需要的結果。

unionWith

Returns every element that exists in any of the two arrays once, using a provided comparator function.

Create a Set with all values of a and values in b for which the comparator finds no matches in a, using Array.findIndex().

const unionWith = (a, b, comp) =>
  Array.from(new Set([...a, ...b.filter(x => a.findIndex(y => comp(x, y)) === -1)]));

對兩個數組的元素分別調用指定比較方法后,返回以運行結果為判定基準的并集,并集是原始數組元素的并集而不是運行結果的并集。

?  code cat unionWith.js
const unionWith = (a, b, comp) =>
  Array.from(new Set([...a, ...b.filter(x => a.findIndex(y => comp(x, y)) === -1)]));

console.log(unionWith([1, 1.2, 1.5, 3, 0], [1.9, 3, 0, 3.9], (a, b) => Math.round(a) === Math.round(b)));

?  code node unionWith.js
[ 1, 1.2, 1.5, 3, 0, 3.9 ]

分主客體,這里主體是前一個數組,即a,表示數組a的所有元素都會保留下來。然后循環數組b,用findIndex方法去把所有對ab的元素調用comp比較方法后的結果不存在于a數組中的所有元素篩選出來。最后把篩選出來的所有元素和數組a組成新數組后再進行集合運算并把運算結果轉化為數組。那就是unionWith的最終結果。

uniqueElements

Returns all unique values of an array.

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

const uniqueElements = arr => [...new Set(arr)];

數組去重。

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

console.log(uniqueElements([1, 2, 2, 3, 4, 4, 5]));

?  code node uniqueElements.js
[ 1, 2, 3, 4, 5 ]

結合ES6的擴展運算符和集合便很容易實現。

unzip

Creates an array of arrays, ungrouping the elements in an array produced by zip.

Use Math.max.apply() to get the longest subarray in the array, Array.map() to make each element an array. Use Array.reduce() and Array.forEach() to map grouped values to individual arrays.

const unzip = arr =>
  arr.reduce(
    (acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc),
    Array.from({
      length: Math.max(...arr.map(x => x.length))
    }).map(x => [])
  );

對于給定的多個數組,返回一個新的二維數組,數組的第一個元素包含多個數組的第一個元素,數組的第二個元素包含多個數組的第二個元素,以此類推(即把zip方法分好組的數組逆向解組)。

使用Math.max.apply()方法來獲取輸入數組的子數組元素個數的最大長度,使用Array.map()來把每一個元素創建成一個數組。然后使用Array.reduce()Array.forEach()去把組里的元素分別加到各自的數組中。

?  code cat unzip.js
const unzip = arr =>
  arr.reduce((acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc),
    Array.from({
      length: Math.max(...arr.map(x => x.length))
    }).map(x => [])
  );

console.log(unzip([["a", 1, true], ["b", 2, false]]));
console.log(unzip([["a", 1, true], ["b", 2]]));

?  code node unzip.js
[ [ "a", "b" ], [ 1, 2 ], [ true, false ] ]
[ [ "a", "b" ], [ 1, 2 ], [ true ] ]
Array.from({
  length: Math.max(...arr.map(x => x.length))
}).map(x => [])

這就是reduce的初始二維數組,用Array.from來生成一個數組,然后再map(x => [])成一個二維數組,那么數組的長度怎么定呢?因為被unzip的原數組里的元素可能是長度不同的數組。那么肯定是以長度最長的那個為準,這樣才能包含解組后的所有元素。這就是length: Math.max(...arr.map(x => x.length))做的事。

對于reduce里的方法:

(acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc)

acc是累加值,在遍歷過程中會一直變化,val.forEach((v, i) => acc[i].push(v))這是遍歷過程中val數組元素push到累加acc對應索引數組的方法。

舉個例子:

原數組arr = [[1, 2, 3], ["a", "b"]],在遍歷過程中初始累加acc = [[], [], []](含有三個元素的數組)。

// 第一次
val = [1, 2, 3]
acc = [[1], [2], [3]]

// 第二次
val = ["a", "b"]
acc = [[1, "a"], [2, "b"], [3]] // 這也是最終結果
unzipWith

Creates an array of elements, ungrouping the elements in an array produced by zip and applying the provided function.

Use Math.max.apply() to get the longest subarray in the array, Array.map() to make each element an array. Use Array.reduce() and Array.forEach() to map grouped values to individual arrays. Use Array.map() and the spread operator (...) to apply fn to each individual group of elements.

const unzipWith = (arr, fn) =>
  arr
    .reduce(
      (acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc),
      Array.from({
        length: Math.max(...arr.map(x => x.length))
      }).map(x => [])
    )
    .map(val => fn(...val));

對于給定的多個數組,返回一個新的二維數組,數組的第一個元素包含多個數組的第一個元素,數組的第二個元素包含多個數組的第二個元素,以此類推(即把zip方法分好組的數組逆向解組),在此基礎上對二維數組的每個元素運行指定方法并返回。

使用Math.max.apply()方法來獲取數組的子數組元素個數的最大長度,使用Array.map()來把每一個元素創建成一個數組。然后使用Array.reduce()Array.forEach()去把組里的元素分別加到各自的數組中。然后再結合 Array.map()和ES6擴展運算符把前面生成的二維數組的每個元素分別調用fn方法。

?  code cat unzipWith.js
const unzipWith = (arr, fn) =>
    arr.reduce((acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc),
        Array.from({
            length: Math.max(...arr.map(x => x.length))
        }).map(x => [])
    )
    .map(val => fn(...val));

console.log(unzipWith([[1, 10, 100], [2, 20, 200]], (...args) => args.reduce((acc, v) => acc + v, 0)));

?  code node unzipWith.js
[ 3, 30, 300 ]

unzipWith就比unzip多了一個對每個二維數組元素調用指定fn方法。即map(val => fn(...val))。其它都和unzip一樣,沒啥可說的了。看以上例子運行結果就知道了。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/107387.html

相關文章

  • JavaScript30入門放棄Array(二)

    摘要:循環一個數組,使用每次去刪除該數組的第一個元素直到指定方法運算結果為,返回的是剩余元素組成的數組。直到循環退出,返回此時的。對應就是,包含下界,不包含上屆。秒,從入門到放棄之二微信公眾號秒,從入門到放棄之二 difference Returns the difference between two arrays. Create a Set from b, then use Array...

    pinecone 評論0 收藏0
  • JavaScript30入門放棄Array(五)

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

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

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

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

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

    Cciradih 評論0 收藏0
  • JavaScript30入門放棄

    摘要:三元運算符遍歷過程中判斷遍歷數組值是否嚴格等于指定值,是,次數否,。三元運算符判斷是否是一個數組,是,返回遞歸運用后的值否,直接返回。秒,從入門到放棄博客地址秒,從入門到放棄微信公眾號地址秒,從入門到放棄 有意思 最近很火的github上的庫30-seconds-of-code,特別有意思,代碼也很優雅。 能學es6 自己翻譯,能學英語 代碼很美,很優雅,美即正義 函數式表達,享受 ...

    TNFE 評論0 收藏0

發表評論

0條評論

Freeman

|高級講師

TA的文章

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