• JS sort排序


    1.定义及用法

    sort() 方法用于对数组的元素进行排序,并返回数组。排序顺序可以是按字母或数字,也可以是升序(向上)或降序(向下)。默认排序顺序是根据字符串UniCode码。

    语法:Array.sort(sortBy);

    参数sortBy可选,用来规定排序的顺序,但必须是函数。

    2.不传递任何参数


    在数组中的值为number​类型时,结果并不是和正常排序一样,而是字符编码的出现顺序排列的。

    var arr = [2, 6, 8, 8, 2, 10]
    console.log(arr.sort())  //[ 10, 2, 2, 6, 8, 8 ]
    
    • 1
    • 2
    const str = ['ab', 'bc', 'cs', 'a', 'dc']
    console.log(str.sort());  // ['a', 'ab', 'bc', 'cs', 'dc']
    
    • 1
    • 2

    在上面的例子中,sort方法中没有传递任何参数,那么他会对数组中的值进行字符编码排序。

    3.传递a,b

    升序:

    var arr = [2, 6, 8, 8, 2, 10]
        arr.sort((a, b) => {
    	return a - b
        })
    console.log(arr)//[2, 2, 6, 8, 8, 10]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    排序:

    var arr = [2, 6, 8, 8, 2, 10]
        arr.sort((a, b) => {
    	return b - a
        })
    console.log(arr)//[ 10, 8, 8, 6, 2, 2 ]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    追根究底,a指什么?b指什么?内部用怎样的方法实现的排序?

    首先改变数组,看一下a指的到底是什么

    var arr = [6, 8, 2, 10, 1]
        arr.sort((a, b) => {
        console.log("a:" + a)
        return 1
    })
    console.log(arr)
    //a:8
    //a:2
    //a:10
    //a:1
    //[6, 8, 2, 10, 1]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    很容易看出a的范围是[arr[1],arr[arr.length-1]]​.另外能看出当函数返回一个正值时,数组并没有发生变化(0也是)

    接下来再看一下b指的是什么

    var arr = [6, 8, 2, 10, 1]
        arr.sort((a, b) => {
        console.log("b:" + b)
        return -1
    })
    console.log(arr)
    //b:6
    //b:8
    //b:2
    //b:10
    //[1, 10, 2, 8, 6]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    4.传递函数

    var array = [4, 8, 128, 1, 64, 2, 16, 32];
    array = array.sort(compare);
    
    function compare(value1, value2) {
      console.log(value1, value2);
      if (value1 < value2) {
        return -1;
      } else if (value1 > value2) {
        return 1;
      } else {
        return 0;
      }
    }
    console.log(array);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    在这里插入图片描述
    从上面我们可以得出,value1 获取的是第二个值,value2获取的是第一个值,它大概是这么进行比较的:

    • 若value1 > value2 ,返回1,那么就是就是进行升序排列。
    • 若value1 < value2 ,返回-1,那么就是降序排列,就需要value1在和之前的值在比较一次
    • 当value1既不小于value2也不大于value2,那么它就不进行比较和排序。
  • 相关阅读:
    JAVA 从入门到起飞 day8 面向对象01
    回归预测 | MATLAB实现贝叶斯优化门控循环单元(BO-GRU)多输入单输出
    酸奶行业内卷成风,品牌乱象层出不穷
    【stm32】FreeModbus 介绍 + 移植stm32f103 HAl库
    在unity中利用公开变量引用物体和组件(有手就会)
    HBase shell常用命令
    Linux从入门到精通(十一)——计划任务
    Mybatis的二级缓存 (Redis方式)
    背完这套 Java 面试八股文,自动解锁面试牛逼症被动技能
    pm2在Windows环境中的使用
  • 原文地址:https://blog.csdn.net/wu_2004/article/details/133811758