Javascript排序结果不正确,什么问题?

标签 javascript

var sor = ['11', '0', '22', '33'];
for(var i = 0 ; i <=10;i++){
     sor.push('11222111111113332323231111'+i);
}

function sortnum(num1,num2){
  return num2-num1;
}
sor.sort(sortnum);

$.each(sor,function(index,val){
     $('div').append(val+'<br/>');
}); 

Firefox 的结果如下:

122111111111333232323111110
12211111111133323232311113
12211111111133323232311119
12211111111133323232311118
12211111111133323232311110
12211111111133323232311111
12211111111133323232311112
12211111111133323232311117
12211111111133323232311114
12211111111133323232311115
12211111111133323232311116
33
22
11
0

但我期望的是:

122111111111333232323111110

12211111111133323232311119
12211111111133323232311118
12211111111133323232311117
12211111111133323232311116
12211111111133323232311115
12211111111133323232311114
12211111111133323232311113
12211111111133323232311112
12211111111133323232311111
12211111111133323232311110
33
22
11
0

最佳答案

通过减去参数,它们将隐式转换为数字。然而,像 122111111111333232323111110 这样的数字就超出了范围,Javascript 可以( native )处理的最大整数是 9007199254740992 (请参阅 this )。

这会导致计算失败。

如果您无论如何都想比较这些字符串化数字,则需要使用自定义比较来比较字符串,而不是依赖内置数学。它可能看起来像这样:

function compare(a, b) {
    if(a.length !== b.length) {
        return b.length - a.length;
    }

    for(var i = 0; i < a.length; i++) {
        if(a[i] !== b[i]) {
            return b[i] - a[i];
        }
    }

    return 0;
}

查看this fiddle 。然而,这仅适用于正整数。

关于Javascript排序结果不正确,什么问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20032778/

相关文章:

javascript - 克隆和附加唯一 ID 后未找到 DOM 元素

javascript - 如何在 netsuite 中使用 suitescript 创建自定义记录?

javascript - 分配条件的三元简写?

javascript - ModalPopupExtender setfocus 问题

javascript - 由于 MIME 类型不允许,无法加载模块脚本

javascript - 当数据库从另一个浏览器/计算机更新时我如何收到通知

javascript - 检查指令是否有属性

javascript - 如何检查 div 的第一个 child 是否处于事件状态

javascript - 无法从 xpage 上选项卡式面板中的编辑框中读取值

javascript - 如何使用 Ruby On Rails 5 播放声音