javascript删除数组元素的七个方法示例


Posted in Javascript onSeptember 09, 2019

前言

在JavaScript中,除了Object之外,Array类型(数组)恐怕就是最常用的类型了。与其他语言的数组相比,JavaScript中的Array非常灵活。这种灵活性有利有弊,好处是其富有创造性,可以提供各种灵活的解决方案;坏处是容易脑子不够用,因为事实上,它太灵活了,灵活到无法控制的抓狂。

前面调侃了几句,回归正题,这里要总结7个在JavaScript中删除Array元素的方法,分别是利用length属性、delete关键字、pop()栈方法、shift()队列方法、splice()操作方法、forEach()或filter()迭代方法和prototype原型方法。

length属性

JavaScript中Array的length属性非常有特点一一它不是只读的。因此,可以通过设置这个属性来达到从数组的末尾移除项或添加新项的目的。

var colors = ["red", "blue", "grey"]; // 创建一个包含3个字符串的数组
colors.length = 2;

console.log(colors[2]); // undefined

delete关键字

JavaScript提供了一个delete关键字用来删除(清除)数组元素。

var colors = ["red", "blue", "grey", "green"];
delete colors[0];

console.log(arr); // [undefined, "blue", "grey", "green"]

要注意的是,使用delete删除元素之后数组长度不变,只是被删除元素被置为undefined了。

pop()栈方法

JavaScript中的Array对象提供了一个pop()栈方法用于弹出并返回数组中的最后一项,某种程度上可以当做删除用。

栈数据结构的访问规则是FILO(First In Last Out,先进后出),栈操作在栈顶添加项,从栈顶移除项,使用pop()方法,它能移除数组中的最后一项并返回该项,并且数组的长度减1。

var colors = ["red", "blue", "grey"];
var color = colors.pop();

console.log(color); // "grey"
console.log(colors.length); // 2

可以看出,在调用pop()方法时,数组返回最后一项,即”grey”,数组的元素也仅剩两项。

shift()队列方法

JavaScript中的Array对象提供了一个shift()队列方法用于弹出并返回数组中的第一项,某种程度上也可以当做删除用。

队列数据结构的访问规则是FIFO(First In First Out,先进先出),队列在列表的末端添加项,从列表的前端移除项,使用shift()方法,它能够移除数组中的第一个项并返回该项,并且数组的长度减1。

var colors = ["red", "blue", "grey"];
var color = colors.shift();

console.log(color); // "red"
console.log(colors.length); // 2

可以看出,在调用shift()方法时,数组返回第一项,即”red”,数组的元素也仅剩两项。

splice()操作方法

在JavaScript的Array对象中提供了一个splice()方法用于对数组进行特定的操作。splice()恐怕要算最强大的数组方法了,他的用法有很多种,在此只介绍删除数组元素的方法。在删除数组元素的时候,它可以删除任意数量的项,只需要指定2个参数:要删除的第一项的位置和要删除的项数。

var colors = ["red", "blue", "grey"];
var color = colors.splice(0, 1);

console.log(color); // "red"
console.log(colors); // ["blue", "grey"]

可以看出,在调用了splice(0, 1)方法时,数组从第一项开始,删除了一项。

迭代方法

所谓的迭代方法就是用循环迭代数组元素,发现符合要删除的项则删除。用的最多的地方,可能是当数组中的元素为对象的时候,可以根据对象的某个属性(例如ID)来删除数组元素。

第一种用最常见的ForEach循环来对比元素找到之后将其删除。

var colors = ["red", "blue", "grey"];

colors.forEach(function(item, index, arr) {
  if(item === "red") {
    arr.splice(index, 1);
  }
});

可以看到这里还要配合splice()方法去实现删除,循环只是为了找到特定的元素。另外一种思路是循环将不需要删除的元素推入到新的数组中,也能达到假性删除特定元素的目的。

第二种我们用循环中的filter方法。

var colors = ["red", "blue", "grey"];

colors = colors.filter(function(item) {
  return item != "red"
});
 
console.log(colors); // ["blue", "grey"]

代码很简单,找出元素不是”red”的项数返回给colors(其实是得到了一个新的数组,并不是在原数组上进行删除操作),一定程度上也算是达到了删除特定元素的目的。

prototype原型方法

可以通过在Array的原型上添加方法来达到删除的目的。

Array.prototype.remove = function(dx) {
if(isNaN(dx) || dx > this.length){


return false;

}


for(var i = 0, n = 0; i < this.length; i++) {


if(this[i] != this[dx]) {



this[n++] = this[i];


}

}

this.length -= 1;
};

var colors = ["red", "blue", "grey"];
colors.remove(1);
console.log(colors); // ["red", "grey"]

这种方法其实就是自己实现一个删除的逻辑,然后把删除方法添加给了Array的原型对象,则在此环境中的所有Array对象都可以使用该方法。尽管可以这么做,但是不推荐在产品化的程序中修改原生对象的原型。道理很简单,如果只是某个实现中缺少某个方法,就在原生对象的原型中添加这个方法,那么当在另一个支持该方法的实现中运行代码时,就可能导致命名冲突。而且这样做可能会意外地导致原生方法被重写。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
阻止JavaScript事件冒泡传递(cancelBubble 、stopPropagation)
May 08 Javascript
Add a Picture to a Microsoft Word Document
Jun 15 Javascript
jquery动画3.创建一个带遮罩效果的图片走廊
Aug 24 Javascript
基于jquery中children()与find()的区别介绍
Apr 26 Javascript
javascript 寻找错误方法整理
Jun 15 Javascript
gridview生成时如何去掉style属性中的border-collapse
Sep 30 Javascript
原生js编写autoComplete插件
Apr 13 Javascript
Bootstrap框架下下拉框select搜索功能
Mar 26 Javascript
jQuery手风琴的简单制作
May 12 jQuery
angular学习之动态创建表单的方法
Dec 07 Javascript
vue简单封装axios插件和接口的统一管理操作示例
Feb 02 Javascript
Vue移动端用淘宝弹性布局lib-flexible插件做适配的方法
May 26 Javascript
微信小程序 select 下拉框组件功能
Sep 09 #Javascript
移动端手指操控左右滑动的菜单
Sep 08 #Javascript
swiper Scrollbar滚动条组件详解
Sep 08 #Javascript
js实现移动端tab切换时下划线滑动效果
Sep 08 #Javascript
swiper4实现移动端导航切换
Oct 16 #Javascript
Swiper.js实现移动端元素左右滑动
Sep 08 #Javascript
vue实现抖音时间转盘
Sep 08 #Javascript
You might like
php 什么是PEAR?(第三篇)
2009/03/19 PHP
tp5框架内使用tp3.2分页的方法分析
2019/05/05 PHP
JQUERY 对象与DOM对象之两者相互间的转换
2009/04/27 Javascript
javascript实现切换td中的值
2014/12/05 Javascript
分享经典的JavaScript开发技巧
2015/11/21 Javascript
通过Tabs方法基于easyUI+bootstrap制作工作站
2016/03/28 Javascript
第三章之Bootstrap 表格与按钮功能
2016/04/25 Javascript
Js 获取当前函数参数对象的实现代码
2016/06/20 Javascript
网络传输协议(http协议)
2016/11/18 Javascript
微信小程序开发中的疑问解答汇总
2017/07/03 Javascript
Java设计中的Builder模式的介绍
2018/03/22 Javascript
JS实现处理时间,年月日,星期的公共方法示例
2019/05/31 Javascript
微信小程序全局变量的设置、使用、修改过程解析
2019/09/24 Javascript
layui use 定义js外部引用函数的方法
2019/09/26 Javascript
vue实现从外部修改组件内部的变量的值
2020/07/30 Javascript
python算法学习之基数排序实例
2013/12/18 Python
python获得图片base64编码示例
2014/01/16 Python
详解Python 模拟实现生产者消费者模式的实例
2017/08/10 Python
基于pip install django失败时的解决方法
2018/06/12 Python
python3.X 抓取火车票信息【修正版】
2018/06/19 Python
使用Python实现毫秒级抢单功能
2019/06/06 Python
python异步Web框架sanic的实现
2020/04/27 Python
pytorch查看通道数 维数 尺寸大小方式
2020/05/26 Python
详解Pymongo常用查询方法总结
2021/01/29 Python
CSS3的新特性介绍
2008/10/31 HTML / CSS
HTML 5 标签、属性、事件及浏览器兼容性速查表 附打包下载
2012/10/20 HTML / CSS
Gucci法国官方网站:意大利奢侈品牌
2018/07/25 全球购物
前台接待的工作职责
2013/11/21 职场文书
优秀求职信范文分享
2014/01/26 职场文书
管理学院毕业生自荐信范文
2014/03/10 职场文书
毕业生找工作自荐书
2014/06/30 职场文书
新店开张活动方案
2014/08/24 职场文书
党员自我剖析材料
2014/08/31 职场文书
学校2014年度工作总结
2014/12/06 职场文书
浅谈Redis在直播场景的实践方案
2021/04/27 Redis
Nginx本地配置SSL访问的实例教程
2022/05/30 Servers