按十进制排序数组,然后按字符串排序 - Javascript

时间:2013-04-09 06:46:02

标签: javascript arrays string sorting

我需要使用普通的旧Javascript对这种格式的数组进行排序。

var arr = ["0.01 BASIC", "0.01 SEF", "0.015 BASIC"];

我需要的是数组首先按十进制排序,然后按字符串排序,并产生如下所示的输出;

arr = ["0.01 BASIC", "0.015 BASIC", "0.01 SEF"];

我不能在执行排序时使用jquery。只是简单的旧Javascript。

3 个答案:

答案 0 :(得分:6)

你可以这样做:

arr.sort(function(a,b){
   var at = a.split(' '), bt = b.split(' ');
   if (at[1]!=bt[1]) return at[1]>bt[1] ? 1 : -1;
   return parseFloat(at[0])-parseFloat(bt[0]);
});

如果要对非常大的数组进行排序,则缓存密钥可能会更快。但它对大多数阵列来说可能并不重要。

Example

["0.01 BASIC", "0.01 SEF", "0.015 BASIC", "0.2 BASIC", "0.001 SEF", "0.2 AAA"]
->
["0.2 AAA", "0.01 BASIC", "0.015 BASIC", "0.2 BASIC", "0.001 SEF", "0.01 SEF"] 

答案 1 :(得分:1)

两个连续的排序将起作用:

arr.sort(function(a,b){
  // sort by words first
  return a.match(/[a-z]+/i).join("")<b.match(/[a-z]+/i).join()?-1:1;
}).sort(function(a,b){
  // sort by numbers next, but only if the words are equal
  return a.match(/[a-z]+/i).join("")!==b.match(/[a-z]+/i).join("")?0:parseInt(a)<parseInt(b)?-1:1;
})

答案 2 :(得分:1)

使用普通的旧Javascript FIDDLE

    var xOriginal = ["0.01 BASIC", "0.015 BASIC", "0.01 SEF"];
    var xTemp = "";

for(var i=0;i<=xOriginal.length-1;i++)
{
for(var j=1;j<=xOriginal.length-1;j++)
{

 var xArr = xOriginal[i].split(" ");
 var yArr = xOriginal[j].split(" ");

  if((xArr[0] > yArr[0]) && (xArr[1] > yArr[1])) 
            {
               xTemp = xOriginal[i];
               xOriginal[i] = xOriginal[j];
               xOriginal[j] = xTemp;
            }


}
}

alert(xOriginal);