Array---常用属性和方法总结
1、Array对象构造函数
1 /*Array对象构造函数*/ 2 3 /*组合记忆 shift unshift pop push 4 添加和删除 5 shift unshift 从数组开头开始添加或者删除 6 pop push 从数组末尾添加或者删除 7 */ 8 9 //shift:删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined 10 var arr1 = [1,2,3,4,5]; 11 var arr2 = [1,2,3,4,5]; 12 var result = arr1.shift(); 13 console.log(result);//a:[2,3,4,5] b:1 14 15 //unshift:将参数添加到原数组开头,并返回数组的长度 16 arr1 = [1,2,3,4,5]; 17 result = arr1.unshift(-2,-1); 18 console.log(result);//a:[-2,-1,1,2,3,4,5] b:7 19 //注:在IE6.0下测试返回值总为undefined, 20 //FF2.0下测试返回值为7,所以这个方法的返回值不可靠,需要用返回值时可用splice代替本方法来使用。 21 22 23 //pop:删除原数组最后一项,并返回删除元素的值;如果数组为空则返回undefined 24 arr1= [1,2,3,4,5]; 25 result = arr1.pop(); 26 console.log(result);//a:[1,2,3,4] b:5 27 28 //push:将参数添加到原数组末尾,并返回数组的长度 29 arr1 = [1,2,3,4,5]; 30 result = arr1.push(6,7); 31 console.log(result);//a:[1,2,3,4,5,6,7] b:7
2、数组合并---concat
1 /*数组合并concat*/ 2 3 //concat:返回一个新数组,是将参数添加到原数组中构成的 4 arr1 = [1,2,3,4,5]; 5 result = arr1.concat(6,7); 6 console.log(result);//a:[1,2,3,4,5] b:[1,2,3,4,5,6,7]
3、数组排序---排序 sort 从小到大, reverse 从大到小
1 /*排序 sort 从小到大 reverse 从大到小*/ 2 // sort(orderfunction):按指定的参数对数组进行排序 3 arr1 = [1,2,3,4,5]; 4 result = arr1.sort(); 5 console.log(result);//[1,2,3,4,5] 6 7 // reverse:将数组反序 8 arr1 = [1,2,3,4,5,8,34]; 9 result = arr1.reverse(); 10 console.log(result);//[34,8,5,4,3,2,1]
4、数组截取---slice(start,end)
1 // slice(start,end):返回从原数组中指定开始下标到结束下标之间的项组成的新数组,但不包括结束位置的项 2 arr1 = [1,2,3,4,5]; 3 result = arr1.slice(2,5); //[3,4,5] 4 result = arr1.slice(2); //[3,4,5] 在只有一个参数的情况下,slice()方法返回从该参数指定位置开始到当前数组末尾的所有项; 5 6 //返回自身 7 result = arr1.slice(0); //返回自身
5、数组拼接成字符串---join(separator)
1 /*join(separator) 数组拼接成字符串*/ 2 //将数组的元素组起一个字符串,以separator为分隔符,省略的话则用默认用逗号为分隔符 3 arr1 = [1,2,3,4,5]; 4 result = arr1.join("|"); //a:[1,2,3,4,5] b:"1|2|3|4|5"
6、splice
1 /*splice*/ 2 //splice(start,deleteCount,val1,val2,...): 3 // 从start位置开始删除deleteCount项,并从该位置起插入val1,val2,... 4 arr1 = [1,2,3,4,5]; 5 result = arr1.splice(2,2,7,8,9); //a:[1,2,7,8,9,5] b:[3,4] 6 result = arr1.splice(0,1); //同shift 7 8 arr1.splice(0,0,-2,-1); 9 result = arr1.length; //同unshift 10 11 result = arr1.splice(arr1.length-1,1); //同pop 12 arr1.splice(arr1.length,0,6,7); 13 result = arr1.length; //同push
7、去除数组中的重复项
1 <script> 2 /*--数组扩展方法--*/ 3 /* 4 *去除数组中的重复项 5 */ 6 Array.prototype.unique = function() { 7 var a = []; var l = this.length; 8 for (var i = 0; i < l; i++) 9 { 10 for (var j = i + 1; j < l; j++) 11 { 12 if (this[i] === this[j]) j = ++i; 13 } 14 a.push(this[i]); 15 } 16 return a; 17 }; 18 19 var arr = [1,2,3,4,5,6,6,7,7,77,7,] 20 console.log(arr.unique());//Array(8) 21 22 </script>