javascript删除数组元素的7个方法

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

前面调侃了几句,回归正题,这里要总结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关键字this

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

var colors = ["red", "blue", "grey", "green"]; delete colors[0]; console.log(colors); // [undefined, "blue", "grey", "green"]

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

pop()栈方法code

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

栈数据结构的访问规则是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对象均可以使用该方法。尽管能够这么作,可是不推荐在产品化的程序中修改原生对象的原型。道理很简单,若是只是某个实现中缺乏某个方法,就在原生对象的原型中添加这个方法,那么当在另外一个支持该方法的实现中运行代码时,就可能致使命名冲突。并且这样作可能会意外地致使原生方法被重写。

 

"别人稍一注意你,你就敞开心扉,你以为这是坦率,其实每每是由于孤独。"

原文出处:https://www.cnblogs.com/yanggb/p/11464821.html

相关文章
相关标签/搜索