前言
数组的常见方法如下:
方法
描述
备注
slice()
从数组中提取 指定的一个或多个元素,返回结果为新的数组
不会改变原数组
splice()
从数组中删除 指定的一个或多个元素,返回结果为新的数组
会改变原数组
concat()
连接两个或多个数组,返回结果为新的数组
不会改变原数组
join()
将数组转换为字符串,返回结果为转换后的字符串
不会改变原数组
reverse()
反转数组,返回结果为反转后的数组
会改变原数组
sort()
对数组的元素,默认按照Unicode编码 ,从小到大进行排序
会改变原数组
数组的常见方法
slice()
slice()
:从数组中提取指定的一个或者多个元素,返回结果为新的数组 (不会改变原来的数组)。
备注:该方法不会改变原数组,而是将截取到的元素封装到一个新数组中返回。
语法 :
1 新数组 = 原数组.slice (开始位置的索引, 结束位置的索引);
举例:
1 2 3 4 5 6 7 8 9 10 11 12 13 var arr = ["a" , "b" , "c" , "d" , "e" , "f" ];var result1 = arr.slice (2 ); var result2 = arr.slice (-2 ); var result3 = arr.slice (2 , 4 ); var result4 = arr.slice (4 , 2 ); console .log ("arr:" + JSON .stringify (arr));console .log ("result1:" + JSON .stringify (result1));console .log ("result2:" + JSON .stringify (result2));console .log ("result3:" + JSON .stringify (result3));console .log ("result4:" + JSON .stringify (result4));
打印结果:
1 2 3 4 5 arr :["a" ,"b" ,"c" ,"d" ,"e" ,"f" ]result1 :["c" ,"d" ,"e" ,"f" ]result2 :["e" ,"f" ]result3 :["c" ,"d" ]result4 :[]
补充 :
很多前端开发人员会用 slice()将伪数组,转化为真数组。写法如下:
1 2 3 array = Array .prototye .slice .call (arrayLike) 或者 array = [].slice .call (arrayLike)
ES6 看不下去这种蹩脚的转化方法,于是出了一个新的 API:(专门用来将伪数组转化成真数组)
1 array = Array .from (arrayLike)
splice()
splice()
:从数组中删除 指定的一个或多个元素,返回结果为新的数组 (会改变原来的数组,会将指定元素从原数组中删除)。
语法:
1 新数组 = 原数组.splice (起始索引index, 需要删除的个数, 第三个参数, 第四个参数...);
上方语法中,第三个及之后的参数,表示:向原数组中添加新的元素,这些元素将会自动插入到开始位置索引的前面。
举例1:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 var arr1 = ["a" , "b" , "c" , "d" , "e" , "f" ];var result1 = arr1.splice (1 ); console .log ("arr1:" + JSON .stringify (arr1));console .log ("result1:" + JSON .stringify (result1));console .log ("-----------------------" );var arr2 = ["a" , "b" , "c" , "d" , "e" , "f" ];var result2 = arr2.splice (-2 ); console .log ("arr2:" + JSON .stringify (arr2));console .log ("result2:" + JSON .stringify (result2));console .log ("-----------------------" );var arr3 = ["a" , "b" , "c" , "d" , "e" , "f" ];var result3 = arr3.splice (1 , 3 ); console .log ("arr3:" + JSON .stringify (arr3));console .log ("result3:" + JSON .stringify (result3));console .log ("-----------------------" );
打印结果:
1 2 3 4 5 6 7 8 9 10 11 arr1:["a" ] result1:["b" ,"c" ,"d" ,"e" ,"f" ] ----------------------- arr2:["a" ,"b" ,"c" ,"d" ] result2:["e" ,"f" ] ----------------------- arr3:["a" ,"e" ,"f" ] result3:["b" ,"c" ,"d" ] -----------------------
举例2:(我们来看看第三个参数 的用法)
1 2 3 4 5 6 7 var arr4 = ["a" , "b" , "c" , "d" , "e" , "f" ];var result4 = arr4.splice (1 , 3 , "千古壹号" , "vae" );console .log ("arr4:" + JSON .stringify (arr4));console .log ("result4:" + JSON .stringify (result4));
打印结果:
1 2 arr4:["a" ,"千古壹号" ,"vae" ,"e" ,"f" ] result4:["b" ,"c" ,"d" ]
concat()
concat()
:连接两个或多个数组,返回结果为新的数组 。(不会改变原数组)
语法:
1 2 新数组 = 数组1. concat (数组2 , 数组3 ...);
举例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 var arr1 = [1 , 2 , 3 ];var arr2 = ["a" , "b" , "c" ];var arr3 = ["千古壹号" , "vae" ];var result1 = arr1.concat (arr2);var result2 = arr2.concat (arr1, arr3);console .log ("arr1 =" + JSON .stringify (arr1));console .log ("arr2 =" + JSON .stringify (arr2));console .log ("arr3 =" + JSON .stringify (arr3));console .log ("result1 =" + JSON .stringify (result1));console .log ("result2 =" + JSON .stringify (result2));
打印结果:
1 2 3 4 5 6 arr1 =[1 ,2 ,3 ] arr2 =["a" ,"b" ,"c" ] arr3 =["千古壹号" ,"vae" ] result1 =[1 ,2 ,3 ,"a" ,"b" ,"c" ] result2 =["a" ,"b" ,"c" ,1 ,2 ,3 ,"千古壹号" ,"vae" ]
从打印结果中可以看到,原数组并没有被修改。
join()
join()
:将数组转换为字符串,返回结果为转换后的字符串 (不会改变原来的数组)。
补充:join()
方法可以指定一个字符串 作为参数,这个字符串将会成为数组中元素的连接符 ;如果不指定连接符,则默认使用 ,
作为连接符,此时和 toString()的效果是一致的
。
语法:
代码举例:
1 2 3 4 5 6 7 8 9 10 11 12 13 var arr = ["a" , "b" , "c" ];var result1 = arr.join (); var result2 = arr.join ("-" ); console .log (typeof arr); console .log (typeof result1); console .log ("arr =" + JSON .stringify (arr));console .log ("result1 =" + JSON .stringify (result1));console .log ("result2 =" + JSON .stringify (result2));
上方代码中,最后三行的打印结果是:
1 2 3 arr =["a" ,"b" ,"c" ] result1 =a,b,c result2 =a-b-c
reverse()
reverse()
:反转数组,返回结果为反转后的数组 (会改变原来的数组)。
语法:
举例:
1 2 3 4 5 6 var arr = ["a" , "b" , "c" , "d" , "e" , "f" ];var result = arr.reverse (); console .log ("arr =" + JSON .stringify (arr));console .log ("result =" + JSON .stringify (result));
打印结果:
1 2 arr =["f" ,"e" ,"d" ,"c" ,"b" ,"a" ] result =["f" ,"e" ,"d" ,"c" ,"b" ,"a" ]
从打印结果可以看出,原来的数组已经被改变了。
sort()方法
sort()方法要好好理解。所以,我们单独用一大段来讲。
sort()
:对数组的元素进行从小到大来排序(会改变原来的数组)。
sort()方法举例:无参时
如果在使用 sort() 方法时不带参,则默认按照Unicode编码 ,从小到大进行排序。
举例1 :(当数组中的元素为字符串时)
1 2 3 4 5 6 var arr1 = ["e" , "b" , "d" , "a" , "f" , "c" ];var result = arr1.sort (); console .log ("arr1 =" + JSON .stringify (arr1));console .log ("result =" + JSON .stringify (result));
打印结果:
1 2 arr1 =["a" ,"b" ,"c" ,"d" ,"e" ,"f" ] result =["a" ,"b" ,"c" ,"d" ,"e" ,"f" ]
举例2 :(当数组中的元素为数字时)
1 2 3 4 5 6 var arr2 = [5 , 2 , 11 , 3 , 4 , 1 ];var result = arr2s.sort (); console .log ("arr2 =" + JSON .stringify (arr2));console .log ("result =" + JSON .stringify (result));
打印结果:
1 2 arr2 =[1 ,11 ,2 ,3 ,4 ,5 ] result =[1 ,11 ,2 ,3 ,4 ,5 ]
上方的打印结果中,你会发现,使用 sort() 排序后,数字11
竟然在数字2
的前面。这是为啥呢?因为上面讲到了,sort()
方法是按照Unicode编码 进行排序的。
那如果我想让 arr2 里的数字,完全按照从小到大排序,怎么操作呢?继续往下看。
sort()方法举例:带参时
如果在 sort()方法中带参,我们就可以自定义 排序规则。具体做法如下:
我们可以在sort()添加一个回调函数,来指定排序规则。回调函数中需要定义两个形参,浏览器将会分别使用数组中的元素作为实参去调用回调函数
浏览器根据回调函数的返回值来决定元素的排序:(重要)
如果返回一个大于0的值,则元素会交换位置
如果返回一个小于0的值,则元素位置不变
如果返回一个0,则认为两个元素相等,则不交换位置
代码举例 :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 var arr3 = [5 , 2 , 11 , 3 , 4 , 1 ];var result = arr3.sort (function (a, b ) {if (a > b) { return 1 ; } else if (a < b) { return -1 ; } else { return 0 ; } }); console .log ("arr3 =" + JSON .stringify (arr3));console .log ("result =" + JSON .stringify (result));
打印结果:
1 2 arr3 =[1 ,2 ,3 ,4 ,5 ,11 ] result =[1 ,2 ,3 ,4 ,5 ,11 ]
上方代码的写法太啰嗦了,其实也可以简化为如下写法:
代码优化 :(冒泡排序)
1 2 3 4 5 6 7 8 9 10 var arr3 = [5 , 2 , 11 , 3 , 4 , 1 ];var result = arr3.sort (function (a, b ) {return a - b; }); console .log ("arr3 =" + JSON .stringify (arr3));console .log ("result =" + JSON .stringify (result));
打印结果:
1 2 arr3 =[1 ,2 ,3 ,4 ,5 ,11 ] result =[1 ,2 ,3 ,4 ,5 ,11 ]
练习
splice()练习:数组去重
代码实现:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 var arr = [1 , 2 , 3 , 2 , 2 , 1 , 3 , 4 , 2 , 5 ];for (var i = 0 ; i < arr.length ; i++) { for (var j = i + 1 ; j < arr.length ; j++) { if (arr[i] == arr[j]) { arr.splice (j, 1 ); j--; } } } console .log (arr);