TypeScript 自定义数组排序

前言

对列表进行排序(根据自定义规则)。

代码

基本原理

.sort使用属性相减(a-b)获取一个基本类型(-1,0,1),如果小于0则将元素放到前面,如果大于0则放到后面,如果等于0则随缘(不同浏览器会有不同解析方式)。

.sort()采用返回数字的函数,而不是布尔值。
如果第一项较小,则需要返回负值; 如果它更大,则为正;如果相等,则为零。
—— 出处:https://cloud.tencent.com/developer/ask/54556

基本类型排序

//待排序数组
var numericArray:Array<number> = [2,3,4,4,1,5,8,11];
//排序完成的数组
var sorrtedArray:Array<number> = numericArray.sort((n1,n2)=> {
    return n1 - n2
}
//打印
console.log(sorrtedArray);

输出

[1, 2, 3, 4, 4, 5, 8, 11] 

复杂类型排序

class Hum{
    public name:string="";
    public age:number=0;
    constructor(name:string,age:number){
        this.name=name;
        this.age=age;
    }
}

let nike=new Hum("Nike",14);
let joine=new Hum("Joine",18);
let frank=new Hum("frank",12);
let baobo=new Hum("Baobo",13);
let wisk=new Hum("Wisk",16);

var humArray:Hum[] = [];
humArray.push(nike);
humArray.push(joine);
humArray.push(frank);
humArray.push(baobo);
humArray.push(wisk);
//排序完成的数组
var sorrtedArray:Array<Hum> = humArray.sort((n1,n2)=> {
        return n1.age - n2.age
    }
);
//打印
console.log(sorrtedArray);

输出

[Hum: {
  "name": "frank",
  "age": 12
}, Hum: {
  "name": "Baobo",
  "age": 13
}, Hum: {
  "name": "Nike",
  "age": 14
}, Hum: {
  "name": "Wisk",
  "age": 16
}, Hum: {
  "name": "Joine",
  "age": 18
}] 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值