JS删除数组中元素

JavaScript040

JS删除数组中元素,第1张

1、splice

splice(index,len,[item])注释:该方法会改变原始数组。

splice有3个参数,它也可以用来替换/删除/添加数组内某一个或者几个值

index:数组开始下标len: 替换/删除的长度 item:替换的值,删除操作的话 item为空

如:arr = ['a','b','c','d']

删除 ---- item不设置

arr.splice(1,1) //['a','c','d'] 删除起始下标为1,长度为1的一个值,len设置的1,如果为0,则数组不变

arr.splice(1,2) //['a','d'] 删除起始下标为1,长度为2的一个值,len设置的2

替换 ---- item为替换的值

arr.splice(1,1,'ttt')//['a','ttt','c','d'] 替换起始下标为1,长度为1的一个值为‘ttt',len设置的1

arr.splice(1,2,'ttt')//['a','ttt','d'] 替换起始下标为1,长度为2的两个值为‘ttt',len设置的1

添加 ---- len设置为0,item为添加的值

arr.splice(1,0,'ttt')//['a','ttt','b','c','d'] 表示在下标为1处添加一项‘ttt'

看来还是splice最方便啦

2、delete

delete删除掉数组中的元素后,会把该下标出的值置为undefined,数组的长度不会变

如:delete arr[1] //['a', ,'c','d'] 中间出现两个逗号,数组长度不变,有一项为undefined

数组删除某个元素,一般直接使用splice方法。

splice方法第一个参数是要删除的数组的索引值,第二个参数是要删除的数量。

当然还有其他的方法,比如直接循环或过滤等,但是推荐使用splice方法。

方法1:

[js] view plain copy

Array.prototype.method1 = function(){

var arr[] //定义一个临时数组

for(var i = 0i <this.lengthi++){//循环遍历当前数组

//判断当前数组下标为i的元素是否已经保存到临时数组

//如果已保存,则跳过,否则将此元素保存到临时数组中

if(arr1.indexOf(this[i]) == -1){

arr.push(this[i])

}

}

return arr

}

方法2:

[js] view plain copy

Array.prototype.method2 = function(){

var h{} //定义一个hash表

var arr[] //定义一个临时数组

for(var i = 0i <this.lengthi++){//循环遍历当前数组

//对元素进行判断,看是否已经存在表中,如果存在则跳过,否则存入临时数组

if(!h[this[i]]){

//存入hash表

h[this[i]] = true

//把当前数组元素存入到临时数组中

arr.push(this[i])

}

}

return arr

}

方法3:

[js] view plain copy

Array.prototype.method3 = function(){

//直接定义结果数组

var arr[this[0]]

for(var i = 1i <this.lengthi++){//从数组第二项开始循环遍历此数组

//对元素进行判断:

//如果数组当前元素在此数组中第一次出现的位置不是i

//那么我们可以判断第i项元素是重复的,否则直接存入结果数组

if(this.indexOf(this[i]) == i){

arr.push(this[i])

}

}

return arr

}

方法4:

[js] view plain copy

Array.prototype.method4 = function(){

//将数组进行排序

this.sort()

//定义结果数组

var arr[this[0]]

for(var i = 1i <this.lengthi++){//从数组第二项开始循环遍历数组

//判断相邻两个元素是否相等,如果相等说明数据重复,否则将元素写入结果数组

if(this[i] !== arr[arr.length - 1]){

arr.push(this[i])

}

}

return arr

}