JavaScript中sort方法排序不正确解决办法

假如你想对一个数组排序,在JS中你会想到sort函数
例如

var arr = [1, 100, 20, 200, 40, 50, 120, 10];
           arr.sort();
           console.log(arr);

控制台中可以看到结果是

[1, 10, 100, 120, 20, 200, 40, 50]

很明显这个结果是不对的,具体可以参考MDN文档中sort方法具体解释

上面的代码改成这样就可以了

  var arr = [1, 100, 20, 200, 40, 50, 120, 10];
        arr.sort(function (a,b) {
            if (a < b ) {           // 按某种排序标准进行比较, a 小于 b
                return -1;
            }
            if (a > b ) {
                return 1;
            }
            // a must be equal to b
            return 0;
        });
        console.log(arr);

控制台结果是

[1, 10, 20, 40, 50, 100, 120, 200]
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScriptsort()方法是一种常用的数组方法,它可以对数组的元素进行排序sort()方法可以对数字、字母、日期等类型的元素进行排序。它使用一个排序算法将数组元素排序,并且不会创建一个新的数组,而是直接修改原始数组。 排序算法的具体实现并不会被公开说明,因为JS引擎采用了多种不同的算法来进行排序,以根据不同的情况和场景进行选择。 sort方法默认将数组元素按照字符串顺序进行排序,即使数组的元素是数字类型。要想在数字排序时获得正确的结果,需要提供一个比较函数来告诉sort方法如何排序。比较函数需要返回一个负数、零或正数,表示相应的值应该在排序后的数组位于上一个值的前面、相同位置或者后面。 例如,如果想要按照数字大小进行升序排序,可以这样写比较函数: function compareNumbers(a, b) { return a - b; } 这个比较函数会返回一个负数、零或正数,表示a应该排在b的前面、和b相同位置或排在b的后面。 sort()方法可以排序数字、字符串、甚至是对象。在排序对象时,需要使用一个比较函数来定义排序规则,以确定哪些属性应该被用来进行排序。 需要注意的是,在使用sort方法时,进行排序时,一定需要提供一个比较函数。如果没有提供比较函数,则sort方法将按照字符串顺序进行排序,结果可能不是我们预期的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值