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('') 不改变字符串 数组 将字符串分割为数组
相关推荐
信看15 小时前
NMEA-GNSS-RTK 定位html小工具
前端·javascript·html
爱吃大芒果15 小时前
Flutter 主题与深色模式:全局样式统一与动态切换
开发语言·javascript·flutter·ecmascript·gitcode
king王一帅16 小时前
流式渲染 Incremark、ant-design-x markdown、streammarkdown-vue 全流程方案对比
前端·javascript·人工智能
踢球的打工仔17 小时前
jquery的基本使用(3)
前端·javascript·jquery
徐同保18 小时前
js 点击按钮 把文本转成文件并下载下来
开发语言·javascript·ecmascript
bug总结19 小时前
前端开发中为什么要使用 URL().origin 提取接口根地址
开发语言·前端·javascript·vue.js·html
程序员爱钓鱼19 小时前
Node.js 编程实战:数据库连接池与性能优化
javascript·后端·node.js
Gomiko20 小时前
JavaScript DOM 原生部分(二):元素内容修改
开发语言·javascript·ecmascript
一招定胜负20 小时前
网络爬虫(第三部)
前端·javascript·爬虫