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 每一项都小于10arr.every(function(x){ return x < 3}); // falsearr.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 不存在返回-1arr.indexOf(1,1); //4 第二个参数为起始位置arr.indexOf(1,-3); //4arr.indexOf(2,-1); //-1arr.lastIndexOf(2); //3arr.lastIndexOf(2,-2); //3arr.lastIndexOf(2,-3); //1
判断是否为数组
Array.isArray([]); // true[] instanceof Array; // true({}).toString.apply([]) === "[object Array]"; // true[].constructor === Array; // true
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。