我需要使用普通的旧Javascript对这种格式的数组进行排序。
var arr = ["0.01 BASIC", "0.01 SEF", "0.015 BASIC"];
我需要的是数组首先按十进制排序,然后按字符串排序,并产生如下所示的输出;
arr = ["0.01 BASIC", "0.015 BASIC", "0.01 SEF"];
我不能在执行排序时使用jquery。只是简单的旧Javascript。
答案 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]);
});
如果要对非常大的数组进行排序,则缓存密钥可能会更快。但它对大多数阵列来说可能并不重要。
["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);