普通数组排序
js中用方法sort()为数组排序。sort()方法有一个可选参数,是用来确定元素顺序的函数。如果这个参数被省略,那么数组中的元素将按照ASCII字符顺序进行排序。如
var arr = ["a", "b", "A", "B"];
arr.sort();
console.log(arr);//["A", "B", "a", "b"]
因为字母A、B的ASCII值分别为65、66,而a、b的值分别为97、98,所以上面输出的结果是 ["A", "B", "a", "b"] 。
如果数组元素是数字
var arr = [15, 8, 25, 3];
arr.sort();
console.log(arr);//[15, 25, 3, 8]
其实,sort方法会调用每个数组项的toString()方法,得到字符串,然后再对得到的字符串进行排序。虽然数值15比3大,但在进行字符串比较时"15"则排在"3"前面。显然,这种结果不是我们想要的,这时,sort()方法的参数就起到了作用,我们把这个参数叫做比较函数。
比较函数接收两个参数,如果第一个参数应该位于第二个之前则返回一个负数,如果两个参数相等则返回0,如果第一个参数应该位于第二个之后则返回一个正数。例子:
var arr = [23, 9, 4, 78, 3];
//比较函数
var compare = (x, y) => x - y
console.log(arr.sort(compare))//[ 3, 4, 9, 23, 78 ]
如果要按降序排序,那么调换xy的位置即可:
var arr = [23, 9, 4, 78, 3];
//比较函数
var compare = (x, y) => x - y
console.log(arr.sort(compare))//[ 78, 23, 9, 4, 3 ]
数组对象排序
如果数组项是对象,我们需要根据数组项的某个属性对数组进行排序,要怎么办呢?其实和前面的比较函数也差不多:
var arr = [{name: "a", age: 25}, {name: "b", age: 24}];
var compare = (obj1, obj2) => obj1.age - obj2.age
console.log(arr.sort(compare))//[ { name: 'b', age: 24 }, { name: 'a', age: 25 } ]
如果数据不是数值而是字符串,那么只需要在compare函数内对字符串转化为数值即可
版权属于:谁把年华错落成诗 所有,转载请注明出处!
本文链接:https://blog.pomears.com/archives/26.html
如果博客部分链接出现404,请留言或者联系博主修复。