前言
本文主要是我对 js sort() 函数的一些疑问,和解决思路
一、sort 函数的使用
1.1 使用
默认情况下,sort()会按照由小到大重新排列数组元素。
2.1问题
但是,sort()会在每一项上调用 String()来转型函数(返回表示相应类型值的字符串),然后比较字符串来决定顺序。如果数组的元素都是数值,
也会先把数组转换为字符串然后再比较、排序。
而字符串排序是按照以下原则:
- 非空字符串 > 空字符串
- 从第一个字符的ASCII值码开始比较,如果一方第一个就比另一方大,那么它就大于另一方,后面的字符不再比较。
- 长度不能直接决定大小,字符串的大小是由左边开始最前面的字符决定的。
所以我们在比较 [0, 1, 5, 10, 15] 的大小时,会发现,sort 得到的结果是 0,1,10,15,5。对照我上面说的字符串比较,不难发现,5是最大的,因为这个5在第一位,5个数字中第一位没有比它还大的。
3.1解决
所以,我们需要让 sort() 方法接收一个比较函数。比如:
function