js删除数组中指定元素的5种方法

2024-11-22前端开发问题
182

在JavaScript中,我们有多种方法可以删除数组中的指定元素。以下给出了5种常见的方法并提供了相应的代码示例:

1.使用splice()方法:
let array = [0, 1, 2, 3, 4, 5];
let index = array.indexOf(2);
if (index > -1) {
  array.splice(index, 1);
}
// array = [0, 1, 3, 4, 5]
2.使用filter()方法:
let array = [0, 1, 2, 3, 4, 5];
array = array.filter(item => item !== 2);
// array = [0, 1, 3, 4, 5]
3.使用pop()和push()方法:
let array = [0, 1, 2, 3, 4, 5];
let newArray = [];
for(let i = 0; i < array.length; i++) {
  if (array[i] !== 2) {
    newArray.push(array[i]);
  }
}
array = newArray;
// array = [0, 1, 3, 4, 5]
4.使用delete操作符:
let array = [0, 1, 2, 3, 4, 5];
let index = array.indexOf(2);
if (index > -1) {
  delete array[index];
}
// array = [0, 1, , 3, 4, 5]
注意使用delete不会改变数组的length,但会在数组相应的位置上生成一个空位(元素值为undefined)。

5.使用slice()方法配合concat()或者扩展操作符完成:
let array = [0, 1, 2, 3, 4, 5];
let index = array.indexOf(2);
if (index > -1) {
  array = array.slice(0, index).concat(array.slice(index + 1));
  // 或者使用扩展操作符
  // array = [...array.slice(0, index), ...array.slice(index + 1)];
}
// array = [0, 1, 3, 4, 5]
这些方法都可以实现删除数组中的指定元素,但每种方法都具有自身的优点和缺点,所以在实际使用时需要结合具体的场景和需求去选择
The End

相关推荐

layui实现laydate日历控件控制之前日期不可选择
具体实现代码如下: laydate.render({ elem: '#start_time', min:0, //,type: 'date' //默认,可不填}); 只要加一个min参数,就可以控制了。0表示之前的日期不可...
2024-11-29 前端开发问题
133

如何使用百度地图API获取地理位置信息
首先,我们需要在百度地图开放平台上申请一个开发者账号,并创建一个应用。在创建应用的过程中,我们会得到一个密钥(ak),这是调用API的凭证。 接下来,我们需要准备一个PHP文件,以便可以在网页中调用。首先,我们需要引入百度地图API的JS文件,代码如下...
2024-11-22 前端开发问题
244

ajax请求获取json数据并处理的实例代码
ajax请求获取json数据并处理的实例代码 $.ajax({ type: 'GET', url: 'https://localhost:44369/UserInfo/EditUserJson',//请求数据 data: json,//传递数据 //dataType:'json/text',//预计服务器返回的类型 timeout: 3000,//请求超时的时间 //回调函数传参 suc...
2024-11-22 前端开发问题
215

js删除数组中指定元素的5种方法
在JavaScript中,我们有多种方法可以删除数组中的指定元素。以下给出了5种常见的方法并提供了相应的代码示例: 1.使用splice()方法: let array = [0, 1, 2, 3, 4, 5];let index = array.indexOf(2);if (index -1) { array.splice(index, 1);}// array = [0,...
2024-11-22 前端开发问题
182

layui 实现实时刷新一个外部的div
主页面上显示了一个合计,在删除和增加的时候需要更改这个总套数的值: //html代码div class="layui-inline layui-show-xs-block" style="margin-left: 10px" id="sumDiv"spanSOP合计:/spanspan${totalNum}/spanspan套/span/div 于是在我们删除这个条数据后,...
2024-11-14 前端开发问题
156

layui 单选框、复选框、下拉菜单不显示问题如何解决?
1. 如果是ajax嵌套了 页面, 请确保 只有最外层的页面引入了layui.css 和 layui.js ,内层页面 切记不要再次引入 2. 具体代码如下 layui.use(['form', 'upload'], function(){ var form = layui.form; form.render(); // 加入这一句});...
2024-11-09 前端开发问题
313