Array数组常用方法
-
添加/删除元素(末尾)
arr.push(arrItem);//返回修改后数组的长度 arr.pop();//无参,删除数组末尾的一个元素,返回被删除的数据。
-
添加/删除元素(首位)
arr.unshift("aaa");//在数组开头添加一个元素,返回数组的长度。(IE6,7返回undefined) arr.shift();//删除数组第一个元素,返回被删除的数据。
-
切除与替换
var arr = [1,2,3,4,5]; arr.splice(n); //从n开始删除至末尾的元素。 arr.splice(index,count); //从index开始,删除count个元素。 arr.splice(index,coungt,item); //从index开始,删除count个元素,item是替换被删除的元素。(item可以是多项)
以上三种形式的都是以数组形式返回被删除的元素。
-
排序
arr.sort();//默认升序,以编码排序。()中可传参,但也只能是函数。 arr.sort( function(a,b) { return a-b; } );//升序; arr.sort( function(a,b) { return b-a; } );//降序; arr.sort( function(a,b) { return 0.5-Math.random(); } );//随机排序;
-
连接concat:连接多个或多个数组,形成一个新的数组。
var new1 = arr1.concat(arr2);//并不会影响原数组。 var new2 = arr1.concat(arr2,arr3);//可传多个参数,连接多个数组。
-
数组反转/倒序
arr.reverse();
- 数值遍历
arr.map(function(item,index){ } );//item指数值的每一项,index指数值的下标。
-
数值过滤
arr.filter(function(item,index){ …… return item; })
- every && some
var arr = [1, 2, 3, 4, 5];
arr.every(function(x){
return x < 10;
}); //true 每一项都小于10
arr.every(function(x){
return x < 3
}); // false
arr.some(function(x){
return x === 3;
});//true 至少有一项等于3
- reduce && reduceRight
var arr = [1, 2, 3];
var sum = arr.reduce(function(x,y){
return x + y
}, 0); //6
//第二个参数是设置第一次的x,如不传第二个参数,则第一次时x=arr[0],y=arr[1];第二次x=x+y,y=arr[2]
var arr = [3, 9, 6];
var max = arr.reduce(function(x,y){
return x > y ? x : y;
});//9
//reduceRight()是从后面开始遍历。
// arr原数组不被改变
- indexOf && lastIndexOf
var arr = [1,2,3,2,1];
arr.indexOf(2);//1 从左到右查找2的索引
arr.indexOf(99); // -1 不存在返回-1
arr.indexOf(1,1); //4 第二个参数为起始位置
arr.indexOf(1,-3); //4
arr.indexOf(2,-1); //-1
arr.lastIndexOf(2); //3
arr.lastIndexOf(2,-2); //3
arr.lastIndexOf(2,-3); //1
- 判断是否为数组
Array.isArray([]); // true
[] instanceof Array; // true
({}).toString.apply([]) === "[object Array]"; // true
[].constructor === Array; // true