JS遍歷List詳解

在前後端開發中,我們常常會操作集合類型的數據,而JS遍歷List無疑是其中最為常見的操作之一。本文將從多個方面對JS遍歷List做詳細的闡述。

一、基本遍歷方式

const list = ['a', 'b', 'c'];
for (let i = 0; i<list.length; i++) {
  console.log(list[i]);
}

上述代碼中使用了for循環遍歷List,中間通過i變量索引每一個元素進行操作。這種方式是JS最基本的遍歷方式,能夠滿足簡單List的遍歷需求。

二、forEach遍歷方式

const list = ['a', 'b', 'c'];
list.forEach(item => {
  console.log(item);
});

forEach是一種遍曆數組的方式,可以接收一個函數作為參數。該遍歷方式具有以下特點:

  • 無需使用循環變量,簡化代碼。
  • forEach不能像普通的循環一樣在中途返回。
  • 無法在forEach內部使用break表達式,需要使用return。
  • 不會改變原數組的值,僅用於遍歷。

三、for…in 和 for…of 遍歷方式

const list = ['a', 'b', 'c'];
for (const index in list) {
  console.log(list[index]);
}

for (const item of list) {
  console.log(item);
}

兩種方式均可以遍歷List,但有以下區別:

  • for…in遍歷出的是List的index,for…of遍歷出的是List的value。
  • for…in遍歷對象屬性時輸出的順序不會按照對象屬性的順序輸出,而for…of遍曆數組時輸出的順序會按照數組元素順序輸出。
  • for…in可以遍歷對象屬性,而for…of不能。

四、map遍歷方式

const list = ['a', 'b', 'c'];
const newList = list.map(item => {
  return item.toUpperCase();
});
console.log(newList); // ['A', 'B', 'C']

map可以將原數組映射為一個新的數組,具有以下特點:

  • 通過傳入一個函數,並且該函數返回一個新的值,來重新生成一個新的數組。
  • 可以使用filter過濾一些滿足特定條件的元素。

五、reduce遍歷方式

const list = [1, 2, 3, 4, 5];
const result = list.reduce((total, num) => {
  return total + num;
}, 0);
console.log(result); // 15

reduce可以通過累加計算得到一個新值,具有以下特點:

  • 可以通過傳入一個函數來對數組元素依次累加,得到一個新的值。
  • 可以通過第二個參數,指定初始值。

六、多維List遍歷

const list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]];
for (let i = 0; i < list.length; i++) {
  for (let j = 0; j < list[i].length; j++) {
    console.log(list[i][j]);
  }
}

多維List遍歷可以通過嵌套循環來實現。需要注意的是,內部循環的索引需要使用不同的變量。

七、Iterator遍歷方式

function makeIterator(list) {
  let nextIndex = 0;
  return {
    next() {
      if (nextIndex < list.length) {
        return {value: list[nextIndex++], done: false};
      } else {
        return {done: true};
      }
    }
  };
}

const list = ['a', 'b', 'c'];
const it = makeIterator(list);
let result = it.next();
while (!result.done) {
  console.log(result.value);
  result = it.next();
}

Iterator是ES6推出的一種遍歷方式,具有以下特點:

  • 可以自定義數據遍歷。
  • 可以定義內部狀態,可以讓遍歷暫停和繼續。

八、async/await實現遍歷

async function asyncForEach(list, callback) {
  for (let i = 0; i < list.length; i++) {
    await callback(list[i], i, list);
  }
}

asyncForEach([1, 2, 3], async(item, index, list) => {
  await new Promise(resolve => {
    setTimeout(() => {
      console.log(item);
      resolve();
    }, 1000);
  });
});

通過async/await實現遍歷具有以下特點:

  • 可以將異步回調同步執行。
  • 可以自定義回調函數的同時將異步代碼注入其中。

結束語

通過以上八種方式,我們可以對JS遍歷List有一個更深入和全面的理解。在開發過程中,我們需要靈活根據實際情況選擇最適合的遍歷方式,提高開發效率。

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

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

相關推薦

  • JS Proxy(array)用法介紹

    JS Proxy(array)可以說是ES6中非常重要的一個特性,它可以代理一個數組,監聽數據變化並進行攔截、處理。在實際開發中,使用Proxy(array)可以方便地實現數據的監…

    編程 2025-04-29
  • Tensor to List的使用

    Tensor to List是TensorFlow框架提供的一個非常有用的函數,在很多的深度學習模型中都會用到。它的主要功能是將TensorFlow中的張量(Tensor)轉換為P…

    編程 2025-04-29
  • Python遍歷集合中的元素

    本文將從多個方面詳細闡述Python遍歷集合中的元素方法。 一、for循環遍歷集合 Python中,使用for循環可以遍歷集合中的每個元素,代碼如下: my_set = {1, 2…

    編程 2025-04-29
  • Python如何遍歷字典中的key和value

    本文將詳細講解Python中如何遍歷字典中的key和value,包括多種遍歷方式以及在遍歷過程中的一些應用場景。 一、遍歷字典中的key和value 在Python中,字典是一種無…

    編程 2025-04-29
  • 解析js base64並轉成unit

    本文將從多個方面詳細介紹js中如何解析base64編碼並轉成unit格式。 一、base64編碼解析 在JavaScript中解析base64編碼可以使用atob()函數,它會將b…

    編程 2025-04-29
  • Node.js使用Body-Parser處理HTTP POST請求時,特殊字符無法返回的解決方法

    本文將解決Node.js使用Body-Parser處理HTTP POST請求時,特殊字符無法返回的問題。同時,給出一些相關示例代碼,以幫助讀者更好的理解並處理這個問題。 一、問題解…

    編程 2025-04-29
  • 如何使用Python將輸出值賦值給List

    對標題進行精確、簡明的解答:本文將從多個方面詳細介紹Python如何將輸出的值賦值給List。我們將分步驟進行探討,以便讀者更好地理解。 一、變量類型 在介紹如何將輸出的值賦值給L…

    編程 2025-04-28
  • t3.js:一個全能的JavaScript動態文本替換工具

    t3.js是一個非常流行的JavaScript動態文本替換工具,它是一個輕量級庫,能夠很容易地實現文本內容的遞增、遞減、替換、切換以及其他各種操作。在本文中,我們將從多個方面探討t…

    編程 2025-04-28
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • Python List查找用法介紹

    在Python中,list是最常用的數據結構之一。在很多場景中,我們需要對list進行查找、篩選等操作。本文將從多個方面對Python List的查找方法進行詳細的闡述,包括基本查…

    編程 2025-04-28

發表回復

登錄後才能評論