1.arr.splice(index,howmany);
返回含有被删除的元素的数组。
原来数组的长度、索引都会相应的改变。
该方法IE5.5以后才支持
2.arr.length=新的值;
会从数组的末尾元素开始删除。
3.
Array.prototype.remove=function(dx)
{
if(isNaN(dx)||dx>this.length){return false;}
for(var i=0,n=0;i<this.length;i++)
{
if(i!=dx)
{
this[n++]=this[i]
}
}
this.length-=1;
}
a = ['3','2','3','4','5'];
alert("elements: "+a+"nLength: "+a.length);
a.remove(2); //删除下标为0的元素
alert("elements: "+a+"nLength: "+a.length);
4.delete arr[1]
这种方式数组长度不变,此时arr[1]变为undefined了,但是也有好处原来数组的索引也保持不变,此时要遍历数组元素可以才用
arr= [1,2,3,4,5];
delete arr[2];
for(var i=0;i<arr.length;i++){
console.log(arr[i]); //输出1,2,undefined,4,5
}
for(index in arr){
document.write(arr[index]); //输出1,2,4,5
}
注:for-in循环一般用来遍历对象属性,因为它无法保证遍历数组的顺序,因此遍历数组一般还是用for循环
(1)var mycars = new Array();
mycars.length=3;
mycars[0] = "Saab"
mycars[1] = "Volvo"
for (x in mycars)
{
document.write(mycars[x] + "<br />") //输出Saab,Volvo
}
document.write("---------------")
for(var i=0;i<mycars.length;i++){
document.write(mycars[i] + "<br />") //输出Saab,Volvo,undefined
}