0

我正在为我的表使用 javascript 类 sorttable(请参见此处:http ://www.kryogenix.org/code/browser/sorttable/ )

但是,我有一张使用科学记数法的表格。当我对列进行排序时,它看起来像这样......

9.43947E-20
9.41332E-22
9.36423E-22
9.35113E-18
9.2744E-23
9.18754E-22
9.09174
8.3981E-22
7.72743E-19
7.69538E-18
7.23656E-19

它没有正确排序。我希望它看起来像这样...

9.09174
9.35113E-18
7.69538E-18
7.72743E-19
7.23656E-19
9.43947E-20
9.41332E-22
9.36423E-22
8.3981E-22
9.2744E-23

有没有可以做到这一点的javascript函数?谢谢。

4

4 回答 4

2

以上将使用我的sortTable库(目前恰好也在背面使用 jQuery):

演示:http: //jsfiddle.net/bBJBa/1/

他们的关键是将字符串值转换为使用类似*1parseFloat代替的数字parseInt

于 2012-05-11T18:36:44.107 回答
1
var myArrayOfNumbersAsStrings.sort(function(a,b){
    if(parseFloat(a) < parseFloat(b)) return -1;
    if(parseFloat(a) > parseFloat(b)) return 1;
    return 0;
});
于 2012-05-11T18:37:47.067 回答
1

尝试这个:

numbers.sort(function(a, b) {
  return Number(a) - Number(b);
}); // => The array "numbers" is now sorted numerically ascending.
于 2012-05-11T18:40:46.420 回答
0

您希望它们从大到小排序-

   var A= [
        '9.43947E-20',
        '9.41332E-22',
        '9.36423E-22',
        '9.35113E-18',
        '9.2744E-23',
        '9.18754E-22',
        '9.09174',
        '8.3981E-22',
        '7.72743E-19',
        '7.69538E-18',
        '7.23656E-19'
    ];
    A.sort(function(a, b){
        return b-a;
    }).join('\n')

    /*  returned value: (String)
    9.09174
    9.35113E-18
    7.69538E-18
    7.72743E-19
    7.23656E-19
    9.43947E-20
    9.41332E-22
    9.36423E-22
    9.18754E-22
    8.3981E-22
    9.2744E-23
    */
于 2012-05-11T18:59:29.523 回答