中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中Array.from()怎么用

發布時間:2021-12-28 11:29:53 來源:億速云 閱讀:157 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關JavaScript中Array.from()怎么用的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

JavaScript 中有一個這樣的函數:Array.from:允許在 JavaScript 集合(如: 數組、類數組對象、或者是字符串、map 、set 等可迭代對象) 上進行有用的轉換。

1. 介紹

在開始之前,我們先回想一下 Array.from() 的作用。語法:

Array.from(arrayLike[, mapFunction[, thisArg]])

    arrayLike:必傳參數,想要轉換成數組的偽數組對象或可迭代對象。

    mapFunction:可選參數,mapFunction(item,index){...} 是在集合中的每個項目上調用的函數。返回的值將插入到新集合中。

    thisArg:可選參數,執行回調函數 mapFunction 時 this 對象。這個參數很少使用。

    例如,讓我們將類數組的每一項乘以2:

    const someNumbers = { '0': 10, '1': 15, length: 2 };Array.from(someNumbers, value => value * 2); // => [20, 30]

    2.將類數組轉換成數組

    Array.from() 第一個用途:將類數組對象轉換成數組。

    通常,你會碰到的類數組對象有:函數中的 arguments 關鍵字,或者是一個 DOM 集合。

    在下面的示例中,讓我們對函數的參數求和:

    function sumArguments() {    return Array.from(arguments).reduce((sum, num) => sum + num);}sumArguments(1, 2, 3); // => 6

    Array.from(arguments) 將類數組對象 arguments 轉換成一個數組,然后使用數組的 reduce 方法求和。

    此外,Array.from() 的第一個參數可以是任意一個可迭代對象,我們繼續看一些例子:

    Array.from('Hey');                   // => ['H', 'e', 'y']Array.from(new Set(['one', 'two'])); // => ['one', 'two']const map = new Map();map.set('one', 1)map.set('two', 2);Array.from(map); // => [['one', 1], ['two', 2]]

    3.克隆一個數組

    在 JavaScript 中有很多克隆數組的方法。正如你所想,Array.from() 可以很容易的實現數組的淺拷貝。

    const numbers = [3, 6, 9];const numbersCopy = Array.from(numbers);numbers === numbersCopy; // => false

    Array.from(numbers) 創建了對 numbers 數組的淺拷貝,numbers === numbersCopy 的結果是 false,意味著雖然 numbersnumbersCopy 有著相同的項,但是它們是不同的數組對象。

    是否可以使用 Array.from() 創建數組的克隆,包括所有嵌套的?挑戰一下!

    function recursiveClone(val) {    return Array.isArray(val) ? Array.from(val, recursiveClone) : val;}const numbers = [[0, 1, 2], ['one', 'two', 'three']];const numbersClone = recursiveClone(numbers);numbersClone; // => [[0, 1, 2], ['one', 'two', 'three']]numbers[0] === numbersClone[0] // => false

    recursiveClone() 能夠對數組的深拷貝,通過判斷 數組的 item 是否是一個數組,如果是數組,就繼續調用 recursiveClone() 來實現了對數組的深拷貝。

    你能編寫一個比使用 Array.from() 遞歸拷貝更簡短的數組深拷貝嗎?如果可以的話,請寫在下面的評論區。

    4. 使用值填充數組

    如果你需要使用相同的值來初始化數組,那么 Array.from() 將是不錯的選擇。

    我們來定義一個函數,創建一個填充相同默認值的數組:

    const length = 3;const init   = 0;const result = Array.from({ length }, () => init);result; // => [0, 0, 0]

    result 是一個新的數組,它的長度為3,數組的每一項都是0。調用 Array.from() 方法,傳入一個類數組對象 { length } 和 返回初始化值的 mapFunction 函數。

    但是,有一個替代方法 array.fill() 可以實現同樣的功能。

    const length = 3;const init   = 0;const result = Array(length).fill(init);fillArray2(0, 3); // => [0, 0, 0]

    fill() 使用初始值正確填充數組。

    4.1 使用對象填充數組

    當初始化數組的每個項都應該是一個新對象時,Array.from() 是一個更好的解決方案:

    const length = 3;const resultA = Array.from({ length }, () => ({}));const resultB = Array(length).fill({});resultA; // => [{}, {}, {}]resultB; // => [{}, {}, {}]resultA[0] === resultA[1]; // => falseresultB[0] === resultB[1]; // => true

    Array.from 返回的 resultA 使用不同空對象實例進行初始化。之所以發生這種情況是因為每次調用時,mapFunction,即此處的 () => ({}) 都會返回一個新的對象。

    然后,fill() 方法創建的 resultB 使用相同的空對象實例進行初始化。不會跳過空項。

    4.2 使用 array.map 怎么樣?

    是不是可以使用 array.map() 方法來實現?我們來試一下:

    const length = 3;const init   = 0;const result = Array(length).map(() => init);result; // => [undefined, undefined, undefined]

    map() 方法似乎不正常,創建出來的數組不是預期的 [0, 0, 0],而是一個有3個空項的數組。

    這是因為 Array(length) 創建了一個有3個空項的數組(也稱為稀疏數組),但是 map() 方法會跳過空項。

    5. 生成數字范圍

    你可以使用 Array.from() 生成值范圍。例如,下面的 range 函數生成一個數組,從0開始到 end - 1

    function range(end) {    return Array.from({ length: end }, (_, index) => index);}range(4); // => [0, 1, 2, 3]

    range() 函數中,Array.from() 提供了類似數組的 {length:end} ,以及一個簡單地返回當前索引的 map 函數 。這樣你就可以生成值范圍。

    6.數組去重

    由于 Array.from() 的入參是可迭代對象,因而我們可以利用其與 Set 結合來實現快速從數組中刪除重復項。

    function unique(array) {  return Array.from(new Set(array));}unique([1, 1, 2, 3, 3]); // => [1, 2, 3]

    首先,new Set(array) 創建了一個包含數組的集合,Set 集合會刪除重復項。

    因為 Set 集合是可迭代的,所以可以使用 Array.from() 將其轉換為一個新的數組。

    這樣,我們就實現了數組去重。

    7.結論

    Array.from() 方法接受類數組對象以及可迭代對象,它可以接受一個 map 函數,并且,這個 map 函數不會跳過值為 undefined 的數值項。這些特性給 Array.from() 提供了很多可能。

    如上所述,你可以輕松的將類數組對象轉換為數組,克隆一個數組,使用初始化填充數組,生成一個范圍,實現數組去重。

    實際上,Array.from() 是非常好的設計,靈活的配置,允許很多集合轉換。

感謝各位的閱讀!關于“JavaScript中Array.from()怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长垣县| 乐亭县| 济南市| 博白县| 姚安县| 阳朔县| 深州市| 淮安市| 五指山市| 府谷县| 会泽县| 万盛区| 隆子县| 饶河县| 山丹县| 贵州省| 溧水县| 新和县| 道真| 兴国县| 永胜县| 丰宁| 浙江省| 拜泉县| 白水县| 宜城市| 扬中市| 碌曲县| 手游| 怀安县| 长白| 高雄县| 扎囊县| 宁都县| 如东县| 宝丰县| 昂仁县| 淄博市| 新宾| 白玉县| 巴林右旗|