sort() 方法时用于对数组中的元素进行排序的,括号中若是没有传入任何排序函数的话,默认的排序规则是按照字母顺序进行排序,说的更准确一点,就是按照字符编码的先后顺序进行排序
var arr = ["Tom","Jack","Rose","Amy","Marry"];
arr.sort();
document.write(arr); // Amy,Jack,Marry,Rose,Tom
因此,如果是对数字排序的话,用默认的排序规则则会出现以下情况
var arr1 = [1,52,3,45,22,7];
arr1.sort();
document.write(arr1); // 1,22,3,45,52,7
这明显是按照字符编码的顺序进行升序排列的,不是我们想要的结果,那应该怎么做呢?很简单,就是给 sort() 方法传入一个排序函数
var arr1 = [1,52,3,45,22,7];
// 升序排列
arr1.sort(function(a,b){
return a-b;
});
document.write(arr1); // 1,3,7,22,45,52
// 降序排列
document.write("</br>");
arr1.sort(function(a,b){
return b-a;
});
document.write(arr1); // 52,45,22,7,3,1
对排序函数的解释
function numberSoet(a,b){
return a-b;
}
其实是类似于冒泡排序的
a表示前一个元素,b表示后一个元素,当 return 值 > 0 的时候,两个元素就会交换顺序,其他情况都不会交换顺序。
因此当返回值为 a-b 时,若值 > 0 ,则 a > b ,此时两个数字交换位置,即 数值更大的数字往后移动,经过多次比较之后,最大的数字会移动到数组最后面的位置,最小的数字会移动到数组最前面的位置,这就实现了升序排列数字
当返回值为 b-a 时,解释如上,实现了降序排列
注意:
任何一种数据类型都可以传入函数实现具体的排序需求,排序规则由我们自己设置,只要记住,return 的值 > 0 的时候,两个元素交换位置。