JavaScript 删除数组中指定元素(5种方法)

在JavaScript中,有五种方法可以删除数组中的指定元素。以下就是这五种方法:

1. 使用 **splice()**方法:

splice() 方法可以从数组中添加/删除项目,然后返回被删除的项目。这个方法需要两个参数:要开始更改数组的索引和要删除的元素数量。

复制代码
let arr = [1, 2, 3, 4, 5];
let index = arr.indexOf(3);  // 获取3的索引,此处应该为2
if (index !== -1) {
    arr.splice(index, 1);  // 删除索引为2的元素,此处应该为3
}
console.log(arr);  // 输出:[1, 2, 4, 5]

2. 使用 **filter()**方法:

filter() 方法创建一个新的数组,其包含通过所提供函数实现的测试的所有元素。这个方法需要一个回调函数作为参数,回调函数会在数组的每个元素上调用,然后返回一个新数组,该数组只包含那些使函数返回 true 的元素。

复制代码
let arr = [1, 2, 3, 4, 5];
let newArr = arr.filter(item => item !== 3);  // 删除所有值为3的元素
console.log(newArr);  // 输出:[1, 2, 4, 5]

3. 使用 slice() **indexOf**方法:

slice() 方法返回一个新的数组对象,这个新的数组对象是一个由原数组的一部分浅复制而来。indexOf() 方法返回在数组中可以找到给定元素的第一个索引,否则返回 -1。如果该元素不存于数组中,则返回 -1。如果参数未提供,则将返回整个数组。

复制代码
let arr = [1, 2, 3, 4, 5];
let index = arr.indexOf(3);  // 获取3的索引,此处应该为2
if (index !== -1) {
    arr = arr.slice(0, index) + arr.slice(index + 1);  // 删除索引为2的元素,此处应该为3
}
console.log(arr);  // 输出:[1, 2, 4, 5]

4. 使用 **some()** **concat()**方法:

some() 方法测试数组中是否存在某个值。concat() 方法用于连接两个或多个数组。这个方法不会改变现有的数组,而是返回一个新数组。

复制代码
let arr = [1, 2, 3, 4, 5];
let index = arr.indexOf(3);  // 获取3的索引,此处应该为2
if (index !== -1) {
    arr = arr.slice(0, index).concat(arr.slice(index + 1));  // 删除索引为2的元素,此处应该为3
}
console.log(arr);  // 输出:[1, 2, 4, 5]

5. 使用 **includes()** **filter()**方法:

includes() 方法判断一个数组是否包含一个指定的值,filter() 方法创建一个新的数组,其包含通过所提供函数实现的测试的所有元素。这个方法需要一个回调函数作为参数,回调函数会在数组的每个元素上调用,然后返回一个新数组,该数组只包含那些使函数返回 true 的元素。

复制代码
let arr = [1, 2, 3, 4, 5];
let newArr = arr.filter(item => !arr.includes(3));  // 删除所有值为3的元素
console.log(newArr);  // 输出:[1, 2, 4, 5]
相关推荐
SuperEugene24 分钟前
Vue3 组合式函数(Hooks)封装规范实战:命名 / 输入输出 / 复用边界 + 避坑|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
cmd28 分钟前
JS深浅拷贝全解析|常用方法+手写实现+避坑指南(附完整代码)
前端·javascript
进击的尘埃29 分钟前
AbortController 实战:竞态取消、超时兜底与请求生命周期管理
前端·javascript
张一凡9329 分钟前
我用 Zustand 三年了,直到遇见 easy-model...
前端·javascript·react.js
张元清30 分钟前
React 拖拽:无需第三方库的完整方案
前端·javascript·面试
zhensherlock41 分钟前
Protocol Launcher 系列:Microsoft Edge 浏览器唤起的优雅方案
javascript·chrome·microsoft·typescript·edge·github·edge浏览器
英俊潇洒美少年1 小时前
Vue3 中 watch的 flush 选项(默认无/`post`/`sync`)的区别
前端·javascript·vue.js
D_C_tyu1 小时前
HTML | 结合Canvas开发具有智能寻路功能的贪吃蛇小游戏实战详解
javascript·算法·游戏·html·bfs
Jay-r1 小时前
樱花雨特效 WebGL实现 短视频同款浪漫视觉效果(附源码下载)
开发语言·javascript·ecmascript·编程·webgl·代码·樱花雨
凤山老林1 小时前
Js如何实现一个抽奖程序
前端·javascript·vue.js