• 被玩坏的数组排序之sort函数


    JavaScript 的数组排序是一个非常常见业务场景
    ECMAScript 为数组提供了一个原生的sort函数,今天我们就来好好看看你对sort函数究竟了解多少。
    首先我们来看一下sort函数的基本信息
    语法:
    arr.sort([compareFunction])
    参数:
    compareFunction [可选]
    用于数组排序规则的比较函数。如果不含有该参数,数组元素按照转换字符串的各个字符的Unicode编码顺序进行排序。
    compareFunction 参数:
    firstElement 用于比较的第一个元素
    secondElement 用于比较的第二个元素
    返回值:
    排序后的数组,返回的是当前数组。
    我们先来看看各种排序的应用方式
    ​没有参数的默认排序

    // 当没有参数传入时 默认按照数组转成字符串后的结果每一位的Unicode编码进行排序
    let arr = [311,43,54,4,40,26,31,33];
    arr.sort();
    console.log(arr); // [26, 31, 311, 33, 4, 40, 43, 54]
    
    • 1
    • 2
    • 3
    • 4

    ​升序排列

    let arr = [311,43,54,4,40,26,31,33];
    arr.sort((a,b) => a - b);
    console.log(arr);  // [4, 26, 31, 33, 40, 43, 54, 311]
    
    • 1
    • 2
    • 3

    降序排列

    let arr = [311,43,54,4,40,26,31,33];
    arr.sort((a,b) => b - a);
    console.log(arr); // [311, 54, 43, 40, 33, 31, 26, 4]
    
    • 1
    • 2
    • 3

    好了,看完升序和降序排列以后我们来聊聊排序的规则。
    如果添加了 compareFunction 那么数组会按该函数的返回值结果进行排序。
    即 compareFunction(a,b) 表示 a,b的比较结果,规则如下:

    • 如果返回值结果小于0,则a和b的顺序不变;
    • 如果返回值结果等于0,则a和b的顺序不变;
    • 如果返回值的结果大于0,a和b会交换位置。
      了解了以上排序结果以后我们可以使用sort方法颠倒数组的顺序(实现类似于reverse方法的效果)
    let arr = [311,43,54,4,40,26,31,33];
    arr.sort(() => -1);
    console.log(arr); // [33, 31, 26, 40, 4, 54, 43, 311]
    
    • 1
    • 2
    • 3

    随机排序

    let arr = [311,43,54,4,40,26,31,33];
    arr.sort((a,b) => Math.random() - 0.5);
    console.log(arr); // 结果为随机排序
    
    • 1
    • 2
    • 3

    ​按照对象指定的属性值进行升序或降序排列

    var arr = [{
        name: 'zhangsan',
        age: 20
    }, {
        name: 'lisi',
        age: 15
    }, {
        name: 'wangwu',
        age: 17
    }, {
        name: 'zhaoliu',
        age: 23
    }, {
        name: 'fengqi',
        age: 31
    }, {
        name: 'xiaoming',
        age: 11
    }];
    
    
    function sortby(prop, rev = true) {
         // prop 属性名
         // rev  升序降序 默认升序
          return function(a, b) {
             var val1 = a[prop]; 
             var val2 = b[prop]; 
             return rev ? val1 - val2 : val2 - val1;
          }
    }
    
    arr.sort(sortby('age')); // 根据age进行升序排列
    arr.sort(sortby('age',false)); // 根据age进行降序排列
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33

    升序排列结果 :
    在这里插入图片描述

    降序排列结果 :
    在这里插入图片描述
    我们再来看看特别的排序方式
    先按奇数升序排列,后按偶数升序排列

    let arr = [311,43,54,4,40,26,31,33];
    arr.sort((a,b)=>{
        if(!(a % 2) && b % 2) return 1; // 首先满足条件a为偶数,b为奇数
        if((a % 2 && b % 2 || !(a % 2) && !(b % 2)) && a > b) return 1; // 判断a b 均为奇数或偶数 且a > b 即可进行升序排序
        return -1;
    });
    console.log(arr); // [31, 33, 43, 311, 4, 26, 40, 54]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
  • 相关阅读:
    主干网络篇 | YOLOv5/v7 更换骨干网络之 EfficientNet | 卷积神经网络模型缩放的再思考
    区块链系统Docker&Kuberntes一键部署
    Docker 07 部署Tomcat
    Ubuntu22.04安装libudev-dev时的Bug
    Debian衍生桌面项目SpiralLinux12.231001发布
    wins10安装ffmpeg
    DST-Character Mod:Sesshoumaru-Introduction
    双十二蓝牙耳机哪款好?双十二平价蓝牙耳机推荐
    SQLServer如何监控阻塞会话
    SLAM经验分享:少年不惧岁月长
  • 原文地址:https://blog.csdn.net/sdasadasds/article/details/127733511