我们使用sort时,很少使用参数,sort(sortby);其中的sortby表示一个比较函数,即按照自定义的条件进行排序。
没有使用参数时,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。举个例子,一目了然:
<script type="text/javascript">
var arr = new Array(6)
arr[0] = "10"
arr[1] = "5"
arr[2] = "40"
arr[3] = "25"
arr[4] = "1000"
arr[5] = "1"
document.write(arr + "<br />")
document.write(arr.sort())
</script>
输出:1,10,1000,25,40,5
想必你已经懂了,没错,字符串先隐式转换成字符编码再进行比较,不要忘记,是左移比较哦。如果想要实现数字大小比较,便可以使用比较函数啦。
那么,现在我们来看一下带比较函数时,他会怎么表现:
官方给出的
如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数
a 和 b,其返回值如下: 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值
其实也比较容易理解,我们来看个例子
var arr = [[1,6],[2,5],[34,32],[32,22],[34,33]];
function t_sort(a,b){
if(a[0]!=b[0]){
return a[0] > b[0];
}else{
return a[1] < b[1];
}
}
arr.sort(t_sort)
这个例子的排序结果,将会按照二维数组第二维的首个元素进行升序,并且在这个基础上,当两个元素大小相同时,以第二个元素进行降序排列。
这个地方要小心,因为在这个比较函数中,a,b即表示即将进行排序的两个元素(可视作任意两个,但是相对位置是确定的,即a是b之前的元素):
返回a[0] > b[0],表示如果a[0]>b[0],即a在b之后(升序);
a[1] < b[1],表示如果a[1] < b[1],a在b之后(降序)。
你可以试试a[0] < b[0],他表示,如果a[0]<b[0],则a在b之后(降序)。
有点绕,不过很有用处。当然,你可以使用另一种方法:
var arr = [[1,6],[2,5],[34,32],[32,22],[34,33]];
function t_sort(a,b){
if(a[0]!=b[0]){
return a[0] - b[0];
}else{
return b[1] - a[1];
}
}
arr.sort(t_sort)