JS数组重排序方法

数组中的两个重排序方法

这两个方法分别为:reverse()和sort();

两个方法的比较

reverse()方法能够反转数组的顺序。

var values = [1, 2, 3, 4, 5];
    values.reverse();//得到的是[5,4,3,2,1]
复制代码

reverse()方法返回值是排序过后的数组。但reverse()方法不够灵活,因此才有了sort()方法。

sort()方法如果不传任何参数,直接调用的话,这个方法只会对数组里的各项进行字符串的对比,这样使得我们得不到想要的排序结果,大家可以去试一下。

因此我们可以给sort()传一个比较函数来得到我们想要的排序结果,大大的提高了灵活性。

var values = [1, 4, 5, 7, 5];
values.sort(compare);//得到的是[1, 4, 5, 5, 7]
function compare (value1, value2) {
    if (value1 < value2) {
        return -1;//如果将返回值与下面的返回值对调,可以得到一个降序的结果
    } else if (value1 > value2) {
        return 1;
    } else {
        return 0;
    }
}
复制代码

如果数组的值是单纯的数值的话可以使用传入一个简单的比较函数进行比较如下:

var values = [1, 4, 5, 7, 5];
values.sort(compare);//得到的是一个升序的结果
function compare (value1, value2) {
    return value1 - value2;//如果将value1和value2对调得到的是一个降序的结果
}
复制代码

如果将传入的值的顺序改变,那么得到的升序和降序将会发生改变,因此传入参数时一定要注意。sort()方法的返回值也是排序之后的数组

一句话总结

在数组排序中,要得到想要的结果常使用的是sort()方法,在使用sort方法时要注意比较函数参数的传递,得到的结果会受到传入参数的影响。

你可能感兴趣的:(JS数组重排序方法)