JavaScript數組拆分詳解

一、基本概念

JavaScript中的數組Aray是一種有序的集合,它可以包含任意類型的數據,包括數字、字元串、對象或函數等。拆分數組指的是將一個大數組按照一定規則,分成若干個小數組。在實際開發中,拆分數組是一個常用的技能,可以有效的幫助我們處理數據。

二、按元素個數拆分

按照元素個數拆分數組是最常用的一種方法,它可以將一個大數組拆成若干個固定大小的小數組。實現這個功能有很多種方法,接下來我們將介紹三種實現方法。

1. splice()方法

const arr = [1, 2, 3, 4, 5];
const size = 2;
const result = [];

while (arr.length) {
  result.push(arr.splice(0, size));
}

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

這個方法每次截取前面的size個元素,將它們推入result數組中,同時從原數組中刪除這些元素。這個過程循環執行,直到原數組為空為止。

2. reduce()方法

const arr = [1, 2, 3, 4, 5];
const size = 2;

const result = arr.reduce((acc, val, i) => {
  const idx = Math.floor(i / size);
  const page = acc[idx] || (acc[idx] = []);
  page.push(val);
  return acc;
}, []);

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

這個方法使用reduce()函數,將原數組逐個遍歷,並根據元素在原數組中的索引,計算出當前元素應該被推入哪個小數組中。如果當前位置沒有小數組,則創造一個新的小數組,並將當前元素推入其中。

3. slice()方法

const arr = [1, 2, 3, 4, 5];
const size = 2;
const result = [];

for (let i = 0; i < arr.length; i += size) {
  const slice = arr.slice(i, i + size);
  result.push(slice);
}

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

這個方法使用了for循環和slice()函數,每次從原數組中取出size個元素,並將它們推入result數組中。

三、按特定條件拆分

除了按照元素個數拆分以外,我們還可以根據需求將數組按照其他條件進行拆分。

1. 根據奇偶性拆分

const arr = [1, 2, 3, 4, 5];
const evens = [];
const odds = [];

for (let i = 0; i < arr.length; i++) {
  if (arr[i] % 2 === 0) {
    evens.push(arr[i]);
  } else {
    odds.push(arr[i]);
  }
}

console.log(evens); // [2, 4]
console.log(odds); // [1, 3, 5]

這個例子將原數組按照奇偶性拆分成了兩個小數組。它使用常規的for循環遍歷原數組,根據元素是否為偶數,將元素推入evens或odds數組中。

2. 根據值的範圍拆分

const arr = [1, 4, 6, 8, 10];
const small = [];
const medium = [];
const large = [];

for (let i = 0; i < arr.length; i++) {
  if (arr[i] < 5) {
    small.push(arr[i]);
  } else if (arr[i] < 9) {
    medium.push(arr[i]);
  } else {
    large.push(arr[i]);
  }
}

console.log(small); // [1, 4]
console.log(medium); // [6, 8]
console.log(large); // [10]

這個例子將原數組按照值的大小拆分成了三個小數組。它使用常規的for循環遍歷原數組,根據元素值的大小,將元素推入small、medium或large數組中。

3. 根據字元串關鍵詞拆分

const arr = ['apple', 'orange', 'mango', 'banana'];
const startsWithO = [];
const containsN = [];

for (let i = 0; i < arr.length; i++) {
  if (arr[i].startsWith('o')) {
    startsWithO.push(arr[i]);
  }
  if (arr[i].includes('n')) {
    containsN.push(arr[i]);
  }
}

console.log(startsWithO); // ['orange']
console.log(containsN); // ['orange', 'mango', 'banana']

這個例子將原數組按照字元串關鍵詞拆分成了兩個小數組。它使用常規的for循環遍歷原數組,根據元素的字元串形式包含特定的關鍵詞,將元素推入startsWithO或containsN數組中。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/257448.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:45
下一篇 2024-12-15 12:45

相關推薦

  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括弧

    在Python中,被中括弧包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括弧。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python二維數組對齊輸出

    本文將從多個方面詳細闡述Python二維數組對齊輸出的方法與技巧。 一、格式化輸出 Python中提供了格式化輸出的方法,可以對輸出的字元串進行格式化處理。 names = [‘A…

    編程 2025-04-29
  • Java創建一個有10萬個元素的數組

    本文將從以下方面對Java創建一個有10萬個元素的數組進行詳細闡述: 一、基本介紹 Java是一種面向對象的編程語言,其強大的數組功能可以支持創建大規模的多維數組以及各種複雜的數據…

    編程 2025-04-28
  • Python數組隨機分組用法介紹

    Python數組隨機分組是一個在數據分析與處理中常用的技術,它可以將一個大的數據集分成若干組,以便於進行處理和分析。本文將從多個方面對Python數組隨機分組進行詳細的闡述,包括使…

    編程 2025-04-28
  • Python數組索引位置用法介紹

    Python是一門多用途的編程語言,它有著非常強大的數據處理能力。數組是其中一個非常重要的數據類型之一。Python支持多種方式來操作數組的索引位置,我們可以從以下幾個方面對Pyt…

    編程 2025-04-28
  • Python語言數組從大到小排序符號的用法介紹

    當我們使用Python進行編程的時候,經常需要對數組進行排序從而使數組更加有序,而數組的排序方式有很多,其中從大到小排序符號是一種常見的排序方式。本文將從多個方面對Python語言…

    編程 2025-04-28
  • 使用JavaScript日期函數掌握時間

    在本文中,我們將深入探討JavaScript日期函數,並且從多個視角介紹其應用方法和重要性。 一、日期的基本表示與獲取 在JavaScript中,使用Date對象來表示日期和時間,…

    編程 2025-04-28

發表回復

登錄後才能評論