今天在书上看到两个方法,一个升序方法一个降序方法,记录下来供以后参考!
javascript提供了两个相关方法
severse() 颠倒数组顺序;
sort()升序排列数组项
var arr = [1,5,2,10,15];
console.log(arr.sort()); //[1, 10, 15, 2, 5]
但是sort()方法会根据测试字符串的结果改变顺序,因为数值5虽然小于10,但在进行字符串比较时,”10”则位于”5”的前边,于是数组的顺序就被修改了(如上边代码所示)。
不用说,这种顺序方式在很多情况下都不是最佳方案。因此sort()方法可以接受一个比较函数作为参数,以便我们指定哪个值位于哪个值的前面。
比较函数接受两个参数,如果第一个参数应该位于第二个之前则返回一个负数,如果两个参数相等则返回0,如果第一个参数应该位于第二个之后则返回第一个正数。
代码如下:
var arr = [1,5,2,10,15];
//var arr = ['a','g','f','s','c'];
//var arr = ['hao','an','you','to','happly','hot'];
function compare(value1,value2){
if(value1 < value2){
return -1;
}else if(value1 > value2){
return 1;
}else{
return 0;
}
}
arr.sort(compare);
console.log(arr);
三个不同内容数组返回结果如下:
//[1, 2, 5, 10, 15]
//["a", "c", "f", "g", "s"]
//["an", "hao", "happly", "hot", "to", "you"]
降序排序方法 和上边的代码差不多,通过交换比较函数的返回值即可!
在下边的例子中,比较函数在第一个值应该位于第二个之后的情况下返回1,而在第一个值应该在第二个之前的情况下返回-1。交换返回值的意思时让更大的值排位更靠前,也就是对数组按照降序排序。
代码如下:
var arr = [1,5,2,10,15];
//var arr = ['a','g','f','s','c'];
//var arr = ['hao','an','you','to','happly','hot'];
function compare(value1,value2){
if(value1 < value2){
return 1;
}else if(value1 > value2){
return -1;
}else {
return 0;
}
}
arr.sort(compare);
console.log(arr);
三个数组返回值如下:
//[15, 10, 5, 2, 1]
//["s", "g", "f", "c", "a"]
//["you", "to", "hot", "happly", "hao", "an"]
如果只想反转数组原来的顺序,使用severse()方法要更快一些。