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('') 不改变字符串 数组 将字符串分割为数组
相关推荐
远航_11 分钟前
10 个被严重低估的 JS 特性,直接少写 500 行代码
前端·javascript
小高00713 分钟前
当前端面临百万级 API 请求:从"修 CSS 的"到架构师的进化之路
前端·javascript·面试
LateFrames16 分钟前
使用 Winform / WPF / WinUI3 / Electron 实现异型透明窗口
javascript·electron·wpf·winform·winui3
Asort21 分钟前
React类组件精要:定义机制与生命周期方法进阶教程
前端·javascript·react.js
陳陈陳22 分钟前
从“变量提升”到“调用栈爆炸”:V8 引擎是如何偷偷执行你的 JavaScript 的?
javascript
San3028 分钟前
深入理解JavaScript执行机制:从变量提升到内存管理
javascript·编程语言·代码规范
用户120391129472630 分钟前
深入理解JavaScript执行机制:从变量提升到调用栈全解析
javascript
weixin_4386943940 分钟前
pnpm 安装依赖后 仍然启动报的问题
开发语言·前端·javascript·经验分享
烟袅1 小时前
深入 V8 引擎:JavaScript 执行机制全解析(从编译到调用栈)
前端·javascript
有点笨的蛋1 小时前
JavaScript 执行机制深度解析:编译、执行上下文、变量提升、TDZ 与内存模型
前端·javascript