JS数组方法全解析|常用API详解
时间:2025-06-29 08:39:08 154浏览 收藏
哈喽!今天心血来潮给大家带来了《JS数组方法大全|Array常用方法解析》,想必大家应该对文章都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习文章,千万别错过这篇文章~希望能帮助到你!
JS数组方法众多,掌握它们能极大提高开发效率。本文全面解析了JS数组常用方法,包括增、删、改、查、排序、迭代等操作。1. 增:push、unshift用于在数组末尾或开头添加元素;concat合并数组不改变原数组。2. 删:pop删除末尾元素;shift删除首个元素;splice可删除或替换元素。3. 改:通过splice或索引直接修改元素。4. 查:indexOf、lastIndexOf查找索引;includes判断是否存在;find和findIndex查找符合条件的元素。5. 排序:sort按指定规则排序;reverse颠倒顺序。6. 迭代:forEach循环执行函数;map生成新数组;filter筛选元素;reduce汇总计算;every和some进行条件判断。7. 其他:join转为字符串;slice截取数组副本;isArray判断是否为数组。高效使用迭代方法需根据场景选择合适的方法,如map转换、filter筛选、reduce汇总。splice功能强大但易误用,需注意参数及对原数组的影响。避免常见错误包括:区分是否改变原数组、正确使用索引、理解回调参数、不在循环中修改数组长度、使用const保护不变数组。
JS数组方法众多,掌握它们能极大提高开发效率。本文将带你全面解析JS数组常用方法,助你玩转数组操作。

解决方案
JS数组提供了丰富的方法,可以对数组进行增、删、改、查、排序等操作。下面是一些常用的方法:

增:
push(element1, ..., elementN)
:向数组末尾添加一个或多个元素,并返回新的数组长度。会改变原数组。unshift(element1, ..., elementN)
:向数组开头添加一个或多个元素,并返回新的数组长度。会改变原数组。concat(array1, ..., arrayN)
:将一个或多个数组合并成一个新数组,不会改变原数组。
删:
pop()
:删除数组末尾的最后一个元素,并返回被删除的元素。会改变原数组。shift()
:删除数组的第一个元素,并返回被删除的元素。会改变原数组。splice(start, deleteCount, item1, ..., itemN)
:从数组中删除或替换一些元素,并返回被删除的元素组成的数组。会改变原数组。start
指定起始位置,deleteCount
指定删除的元素个数,item1, ..., itemN
指定要添加的新元素。
改:
splice(start, deleteCount, item1, ..., itemN)
:除了删除,还可以替换元素。- 直接通过索引修改数组元素:
arr[index] = newValue;
查:
indexOf(searchElement, fromIndex)
:返回数组中第一个找到指定元素的索引,如果不存在则返回 -1。lastIndexOf(searchElement, fromIndex)
:返回数组中最后一个找到指定元素的索引,如果不存在则返回 -1。includes(searchElement, fromIndex)
:判断数组是否包含指定元素,返回true
或false
。find(callback(element, index, array), thisArg)
:返回数组中第一个满足提供的测试函数的元素的值,否则返回undefined
。findIndex(callback(element, index, array), thisArg)
:返回数组中第一个满足提供的测试函数的元素的索引,否则返回 -1。
排序:
sort(compareFunction)
:对数组的元素进行排序,并返回排序后的数组。会改变原数组。可以传入一个比较函数compareFunction
来指定排序规则。如果没有提供compareFunction
,则按照字符串的 Unicode 码点进行排序。reverse()
:颠倒数组中元素的顺序,并返回修改后的数组。会改变原数组。
迭代:
forEach(callback(element, index, array), thisArg)
:对数组的每个元素执行一次给定的函数。map(callback(element, index, array), thisArg)
:创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。filter(callback(element, index, array), thisArg)
:创建一个新数组,包含通过所提供函数实现的测试的所有元素。reduce(callback(accumulator, currentValue, currentIndex, array), initialValue)
:对数组中的每个元素执行一个reducer函数(升序执行),将其结果汇总为单个返回值。reduceRight(callback(accumulator, currentValue, currentIndex, array), initialValue)
:与reduce()
类似,但它是从数组的末尾开始执行。every(callback(element, index, array), thisArg)
:测试数组中的所有元素是否都通过了指定函数的测试。some(callback(element, index, array), thisArg)
:测试数组中是不是至少有1个元素通过了指定函数的测试。
其他:
join(separator)
:将数组中的所有元素连接成一个字符串。slice(beginSlice, endSlice)
:返回一个新的数组对象,这一对象是一个由beginSlice
和endSlice
决定的原数组的浅拷贝(包括beginSlice
,不包括endSlice
)。原始数组不会被改变。isArray(obj)
:判断一个对象是否为数组。
如何高效使用JS数组的迭代方法?
高效使用迭代方法关键在于选择最适合场景的方法。map
用于转换数组元素,filter
用于筛选元素,reduce
用于汇总计算,forEach
用于简单循环,every
和 some
用于条件判断。例如,需要将数组中的数字都乘以2,用 map
最合适;需要找出数组中所有大于10的数字,用 filter
最合适。理解每个方法的用途能避免不必要的性能损耗。
const numbers = [1, 2, 3, 4, 5]; // 使用 map 将每个数字乘以 2 const doubledNumbers = numbers.map(number => number * 2); console.log(doubledNumbers); // [2, 4, 6, 8, 10] // 使用 filter 筛选出大于 2 的数字 const largeNumbers = numbers.filter(number => number > 2); console.log(largeNumbers); // [3, 4, 5] // 使用 reduce 计算数组元素的总和 const sum = numbers.reduce((accumulator, currentValue) => accumulator + currentValue, 0); console.log(sum); // 15
splice
方法的强大之处与常见误用
splice
方法非常强大,可以用于删除、插入和替换数组元素。它的第一个参数是起始索引,第二个参数是要删除的元素个数,后面的参数是要插入的新元素。常见的误用是忘记 splice
会改变原数组,以及对起始索引和删除个数的理解错误。
const fruits = ['apple', 'banana', 'orange', 'grape']; // 删除从索引 1 开始的 2 个元素 const removedFruits = fruits.splice(1, 2); console.log(fruits); // ['apple', 'grape'] console.log(removedFruits); // ['banana', 'orange'] // 在索引 1 处插入 'kiwi' 和 'mango' fruits.splice(1, 0, 'kiwi', 'mango'); console.log(fruits); // ['apple', 'kiwi', 'mango', 'grape'] // 将索引 2 处的元素替换为 'pear' fruits.splice(2, 1, 'pear'); console.log(fruits); // ['apple', 'kiwi', 'pear', 'grape']
如何避免JS数组操作中的常见错误?
避免JS数组操作中的常见错误,需要注意以下几点:
- 区分改变原数组和不改变原数组的方法。 例如,
push
、pop
、shift
、unshift
、splice
、sort
和reverse
会改变原数组,而concat
、slice
、map
、filter
和reduce
不会改变原数组。 - 注意索引的起始位置。 JS数组的索引从 0 开始。
- 理解迭代方法的参数。 迭代方法的回调函数通常接受三个参数:当前元素、当前索引和数组本身。
- 避免在循环中修改数组的长度。 这可能会导致意想不到的结果。如果需要在循环中修改数组的长度,可以考虑使用
filter
或创建一个新的数组。 - 使用
const
声明不会被修改的数组。 这可以防止意外修改数组。
// 错误示例:在循环中删除数组元素 const numbers = [1, 2, 3, 4, 5]; for (let i = 0; i < numbers.length; i++) { if (numbers[i] % 2 === 0) { numbers.splice(i, 1); // 删除偶数 } } console.log(numbers); // [1, 3, 5] (可能不是你期望的结果,因为数组长度改变导致循环跳过了一些元素) // 正确示例:使用 filter 创建一个新数组,只包含奇数 const numbers = [1, 2, 3, 4, 5]; const oddNumbers = numbers.filter(number => number % 2 !== 0); console.log(oddNumbers); // [1, 3, 5]
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
353 收藏
-
256 收藏
-
420 收藏
-
453 收藏
-
147 收藏
-
256 收藏
-
146 收藏
-
198 收藏
-
290 收藏
-
154 收藏
-
431 收藏
-
359 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习