数组的排序的重要性不必多说,到处可见,现在来说说sort()方法的使用与自定义比较器
sort()方法:默认将数组中的所有元素转为字符串后再排列(默认是升序),用来排列字符串类型的元素
比如一个数组:
var array=[3,5,7,6,1,4,2];
array.sort();
console.log(String(array)); //1,2,3,4,5,6,7
这里成功的进行了排序,但是如果换一个数组:
var array=[123,222,7,67,3,58,92];
array.sort();
console.log(String(array)); //123,222,3,58,67,7,92
结果就没有成功排序,原因是什么?
因为sort()进行的字符串的排序,字符串之间的比较是Unicode码的比较,所以无法完成这个数组的排序,如何解决这个问题?
解决的办法就是使用自定义比较器:
自定义比较器的默认公式:
function cmp(a,b){return a-b};
我们再次对数组var array=[123,222,7,67,3,58,92]排序
var array=[123,222,7,67,3,58,92];
function cmp(a,b){return a-b;};
array.sort(cmp); //直接将cmp放入sort中,不要加括号!!
console.log(String(array)); //3,7,58,67,92,123,222
这次,我们成功的利用自定义比较器进行了排序
说明一下:
1.自定义比较器的原理:
两个参数a,b
如果a>b 则a-b>0 返回一个正数
如果a<b 则a-b<0 返回一个负数
如果a=b 则a-b=0 返回0
2.何时使用自定义比较器?
只要sort默认的排序规则不是我们想要的,就要将自定义比较器函数传入到sort中,代替默认规则
3.为什么sort(cmp)中的cmp不加括号呢?
因为如果是sort(cmp); 我们传入sort中的是一个回调函数,将一个函数作为参数传入另一个函数中反复使用
如果是sort(cmp()); 我们传入的仅仅是一个值
4.如果我们不想进行升序排序,想进行降序排序怎么办?
解决办法: 颠倒比较器的正负号
比如:function cmp(a,b){return b-a;}