默认情况下,sort( )排序按照升序进行排列。为此,sort( )会在每一项上调用String( )转型函数,然后比较字符串来决定顺序。
const a = [3, 2, 4, 1]
a.sort()
console.log(a); //1,2,3,4
一开始数组中的顺序是正确的,调用sort()会按照这些数值的字符串形式重新排列。因此,即使5小于10,但字符串“10”在字符串“5”的前面,所以10还是会排到5前面。
const b = [0, 1, 5, 10, 15, 20]
b.sort()
console.log(b);//0,1,10,15,20,5
很明显,这在多数情况下是不适合的,所以,sort()方法可以接收一个比较函数,用于判断哪个值排在前面。下面是一个比较简单的比较函数:
function compare(value1, value2) {
if (value1 < value2) {
return -1
} else if (value1 > value2) {
return 1
} else {
return 0
}
}
const b = [0, 1, 5, 10, 15, 20]
b.sort(compare)
console.log(b);//0,1,5,10,15,20
这个比较函数适用于大多数数据类型,可以把它当作参数传给sort()方法。
当然,比较函数也可以产生 降序效果 ,只需要把返回值交换一下:
function compare(value1, value2) {
if (value1 < value2) {
return 1
} else if (value1 > value2) {
return -1
} else {
return 0
}
}
const b = [0, 1, 5, 10, 15, 20]
b.sort(compare)
console.log(b);//20,15,10,5,1,0
确实在这例子中使用reverse()反转数组更快。