数组排序sort()小结

先看结果

你想对下面两种类型数组排序?那就接着往下看
var list = [1, 3, 9, 5];
var list3 = [
  { "name": "Tom0", "age": 10 },
  { "name": "Tom1", "age": 18 },
  { "name": "Tom2", "age": 16 },
  { "name": "Tom3", "age": 15 }
];

简单运用

sort()方法是按升序排列数组项的,是直接在原数组上做修改。

var list = [1, 3, 9, 5];
list.sort();
console.log(list);// [ 1, 3, 5, 9 ]嗯是我想要的,不过!!

原理介绍

它是将数组项转化为字符串进行比较,比较的是ASCII码的大小,"19"中 "1"比"3"小所以排在前面。

var list1 = [1, 3, 19, 5];
list1.sort();
console.log(list1);// [ 1, 19, 3, 5 ]

如何“正确”的比较大小?

sort方法可以接收一个比较函数作为参数,让我们来决定哪个值排在前面。比较函数接收两个参数,如果第一个参数位于第二个参数前面就返回一个负数,如果两个参数相等就返回0,如果第一个参数位于第二个参数后面就返回一个正数。以下是一个简单的比较函数。

function compare(val1, val2) {
  if (val1 < val2) {
    return -1;
  } else if (val1 > val2) {
    return 1;
  } else {
    return 0;
  }
}
var list2 = [1, 3, 19, 5];
list2.sort(compare);
console.log(list2);//[ 1, 3, 5, 19 ]

此时我们就能点进阶了

var list3 = [
  { "name": "Tom0", "age": 10 },
  { "name": "Tom1", "age": 18 },
  { "name": "Tom2", "age": 16 },
  { "name": "Tom3", "age": 15 }
];
function compareFun(key) {
  return function (obj1, obj2) {
    return obj1[key] - obj2[key];
  }
}
list3.sort(compareFun("age"))
/*
*[
*  { name: 'Tom0', age: 10 },
*  { name: 'Tom3', age: 15 },
*  { name: 'Tom2', age: 16 },
*  { name: 'Tom1', age: 18 }
*]
*/

总结

这几天看js时遇到了这方法的介绍感觉不错,特地写下记录怕以后忘掉,参考资料菜鸟教程廖雪峰的官方网站

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值