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/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

发表回复

登录后才能评论