js中的sort方法

soft()方法原理

js中的sort方法不同于Java中的soft方法,默认的按照升序排列数组项–最小的排在最前面,最大的排在最后面。
但在js中,sort方法会调用每个数组项的toString()转型方法,然后比较得到的字符串,以确定如何排序,即使数组中每一项都是数组,sort()方法比较的也是字符串。
如:

var values = [0.1,5,10,15];
values.sort();
alert(values);///0,1,10,15,5

可见,即使例子中的值的顺序没有问题,但soft()方法也会根据cesium字符串的结果改变原来的顺序。因为数值5虽然小于10,但在进行字符串比较时,“10”位于“5”的前面,于是数组的顺序就被修改了。所以在大部分,这种排序方法不是最佳的方法。
但soft()方法可以接受一个比较函数作为参数,以便我们指定哪个值位于哪个值前面。
该比较函数接收两个参数,如果第一个参数应该位于第二个参数的前面则返回一个负数,如果两个参数相等,则返回0,如果第一个参数应位于第二个参数的之后,则返回一个正数,以下就是一个简单的比较函数

function compare(value1,value2){
if(value1 < value2){
    return -1;
}else if(value1 > value2){
   return 1;
}else{
   return 0;
}
}

上述的比较函数可以适用于大都数数据类型,只要将其作为参数传递给soft()方法即可,如下:

var values = [0.1,5,10,15];
values.sort(compare);
alert(values);///0,1,5,10,15

如果想要达到降序的结果,就是将比较函数改动一下

function compare(value1,value2){
if(value1 < value2){
    return 1;
}else if(value1 > value2){
   return -1;
}else{
   return 0;
}
}

var values = [0.1,5,10,15];
values.sort(compare);
alert(values);///0,1,5,10,15

当然想要反转数组原来的顺序,直接使用reverse()方法即可

总结

对于数值类型或者其valueOf()方法会返回数值类型的对象类型,可以使用一个更简单的比较函数。这个函数只要用第二个参数减去第一个参数即可

function compare(value1,value2){
return value2-value1;
}

由于比较函数通过返回一个小于零,等于零或者大于零的值影响排序结果,因此减法操作就可以适当的处理所有这些情况。

猜你喜欢

转载自blog.csdn.net/m0_37686205/article/details/89163074
今日推荐