JavaScript遍历数组的方法总结

一、for循环

通过索引遍历数组

ini 复制代码
const arr = [1, 2, 3, 4];
for(let i = 0; i < arr.length; i++){
    console.log(arr[i]);
}

二、forEach()

forEach()是数组的一个方法,允许你对数组的每一项执行回调函数

ini 复制代码
const arr = [1, 2, 3, 4];
arr.forEach(item => console.log(item));

三、map()

map()方法创建一个新数组,其中每个元素是通过调用通过的函数继续转换的结果

ini 复制代码
const arr = [1, 2, 3, 4];
const newArr = arr.map(item => item*2);
console.log(newArr);
//[2, 4, 6, 8]

四、filter()

filter()方法创建一个新数组,包含所有通过回调函数测试的元素(返回true的元素)

ini 复制代码
const arr = [1, 2, 3, 4];
const sum = arr.filter(item => item % 2 === 0);
//[2, 4]

五、reduce()

reduce()方法对数组中的每个元素执行一个提供的函数,并将结果汇总为单个值

ini 复制代码
const arr = [1, 2, 3, 4];
//0代表的是acc的初始值
const sum = arr.reduce((acc, item) => acc + item, 0);
console.log(sum);
//10
//可以用于展开数组
const arrs = [[1, 2, 3], [4, 5], [6]];
//[]代表acc的初值为空数组;concat()方法将acc和_arr数组合并,返回一个新数组
const flattened = arrs.reduce((acc, _arr) => acc.concat(_arr), []);
//[1, 2, 3, 4, 5, 6]

六、some()

some()方法测试数组中是否至少一个元素通过的测试函数。若符合一个则返回ture,否则返回false

ini 复制代码
const arr = [1, 2, 3, 4];
const result = arr.some(item => item % 2 === 0);
console.log(result);
//true

七、every()

every()方法测试数组中的所有元素是否都通过了测试的函数。若都符合则返回true,否则返回false

ini 复制代码
const arr = [2, 4, 6, 8];
const result = arr.some(item => item % 2 === 0);
console.log(result);
//true

八、find()

find()方法用于返回满足测试函数中的第一个元素。若没有找到,则返回undefined

ini 复制代码
const arr = [1, 2, 3, 4];
const found = arr.find(item => item > 2);
console.log(found);
//3

九、findIndex()

findIndex()方法用于返回满足测试函数中的第一个元素的索引。没有找到返回undefined

ini 复制代码
const arr = [1, 2, 3, 4];
const index = arr.findIndex(item => item > 2);
console.log(index);
//2

十、for...of

直接遍历数组中的元素

ini 复制代码
const arr = [1, 2, 3, 4];
for(const item of arr)
    console.log(item);

十一、for...in

遍历数组的索引(或对象的属性)

ini 复制代码
const arr = [1, 2, 3, 4];
for(const key in arr)
    console.log(arr[key]);

但这个方法遍历数组可能会导致访问数组的其他属性

ini 复制代码
const arr = [1, 2];
arr.otherItem = 'hello';
for(const key in arr)
    console.log(key, arr[key]);
//0 1
//1 2
//othetItem hello
相关推荐
柒@宝儿姐15 小时前
vue3中使用element-plus的el-scrollbar实现自动滚动(横向/纵横滚动)
前端·javascript·vue.js
Geoffwo15 小时前
Electron打包的软件如何使用浏览器插件
前端·javascript·electron
智航GIS16 小时前
7.1 自定义函数
前端·javascript·python
Summer不秃17 小时前
使用 SnapDOM + jsPDF 生成高质量 PDF (含多页分页, 附源码)
前端·javascript·vue.js·pdf·node.js
灯把黑夜烧了一个洞18 小时前
2026年跨年倒计时网页版
javascript·css·html·2026跨年代码·新年代码
zhenryx18 小时前
React Native 横向滚动指示器组件库(淘宝|京东...&旧版|新版)
javascript·react native·react.js
POLITE318 小时前
Leetcode 54.螺旋矩阵 JavaScript (Day 8)
javascript·leetcode·矩阵
licongmingli18 小时前
vue2 基于虚拟dom的下拉选择框,保证大数据不卡顿,仿antd功能和样式
大数据·前端·javascript·vue.js·anti-design-vue
小沐°18 小时前
vue3-父子组件通信
前端·javascript·vue.js
码界奇点18 小时前
基于逆向工程技术的Claude Code智能Agent系统分析与重构研究
javascript·ai·重构·毕业设计·源代码管理