JavaScript 数组方法总结

一、数组遍历方法

方法 使用示例 是否改变原数组 返回值 作用
forEach() arr.forEach(element => console.log(element)) 遍历数组,对每个元素执行函数
for...of 循环 for (const value of arr) console.log(value) 遍历数组的值

二、数组转换与映射方法

方法 使用示例 是否改变原数组 返回值 作用
map() let newArr = arr.map(element => element *2) 新数组,包含每次函数调用结果 创建新数组,每个元素执行函数
filter() let newArr = arr.filter(element => element > 3) 新数组,包含符合条件元素 创建新数组,包含符合条件的元素
concat() let newArr = arr.concat(otherArray) 新数组 合并数组
slice() let newArr = arr.slice(start, end) 新数组 提取数组的一部分
flat() let newArr = arr.flat(depth) 新数组 将数组扁平化
flatMap() let newArr = arr.flatMap(element => newArray) 新数组 映射并扁平化数组

三、数组添加与删除方法

方法 使用示例 是否改变原数组 返回值 作用
push() let newLength = arr.push(newElement) 新数组长度 添加元素到数组末尾
pop() let element = arr.pop() 被删除的元素 删除数组末尾元素
shift() let element = arr.shift() 被删除的元素 删除数组开头元素
unshift() let newLength = arr.unshift(newElement) 新数组长度 添加元素到数组开头
splice() let removed = arr.splice(startIndex, deleteCount) 被删除元素数组 删除、替换或添加元素

四、数组查找与检测方法

方法 使用示例 是否改变原数组 返回值 作用
every() let result = arr.every(element => element < 6) 布尔值,truefalse 测试所有元素是否符合条件
some() let result = arr.some(element => element > 4) 布尔值,truefalse 测试是否有元素符合条件
indexOf() let index = arr.indexOf(targetElement) 索引值或 -1 查找元素第一次出现的索引
lastIndexOf() let index = arr.lastIndexOf(targetElement) 索引值或 -1 查找元素最后一次出现的索引
find() let element = arr.find(element => condition) 元素值或 undefined 查找符合条件的第一个元素
findIndex() let index = arr.findIndex(element => condition) 索引值或 -1 查找符合条件的第一个元素的索引
includes() let result = arr.includes(targetElement) 布尔值,truefalse 判断数组是否包含某个元素

五、数组排序与反转方法

方法 使用示例 是否改变原数组 返回值 作用
sort() arr.sort((a, b) => a - b) 原数组 对数组元素排序
reverse() arr.reverse() 原数组 反转数组元素顺序

六、数组归约方法

方法 使用示例 是否改变原数组 返回值 作用
reduce() let result = arr.reduce((acc, curr) => acc + curr, initialValue) 累加结果 数组元素累加
reduceRight() let result = arr.reduceRight((acc, curr) => acc + curr, initialValue) 累加结果 数组元素从右往左累加

七、数组转换为字符串方法

方法 使用示例 是否改变原数组 返回值 作用
join() let str = arr.join(separator) 字符串 将数组元素连接为字符串
split() let arr = str.split('') 不改变字符串 数组 将字符串分割为数组
相关推荐
爱吃鱼的锅包肉几秒前
Flutter路由模块化管理方案
前端·javascript·flutter
风清扬雨27 分钟前
Vue3具名插槽用法全解——从零到一的详细指南
前端·javascript·vue.js
海盗强1 小时前
Vue 3 常见的通信方式
javascript·vue.js·ecmascript
oscar9992 小时前
JavaScript与TypeScript
开发语言·javascript·typescript
橘子味的冰淇淋~2 小时前
【解决】Vue + Vite + TS 配置路径别名成功仍爆红
前端·javascript·vue.js
leluckys2 小时前
flutter 专题 六十三 Flutter入门与实战作者:xiangzhihong8Fluter 应用调试
前端·javascript·flutter
鱼樱前端3 小时前
让人头痛的原型和原型链知识
前端·javascript
lianghj4 小时前
前端高手必备:深度解析高频场景解决方案与性能优化实战
前端·javascript·面试
OpenIM4 小时前
Electron Demo 的快速编译与启动
前端·javascript·electron