我需要对一组字母数字项目进行如下排序。从:
2 xxx
20 axxx
38 xxxx
20 bx
8540 xxxxxx
至:
8540 xxxxx
38 xxxx
20 axxx
20 bx
2 xxx
因此,按照数字降序排列,然后按字母升序排列。数字总是用一个空格与字母字符(表示为“xxxx”)分开,但数字是可变长度的。
我怀疑我需要在 sort() 函数中使用一些正则表达式并按空格分割数字然后对其进行排序,但我不知道如何配合字母排序。任何代码示例?非常感谢!
我需要对一组字母数字项目进行如下排序。从:
2 xxx
20 axxx
38 xxxx
20 bx
8540 xxxxxx
至:
8540 xxxxx
38 xxxx
20 axxx
20 bx
2 xxx
因此,按照数字降序排列,然后按字母升序排列。数字总是用一个空格与字母字符(表示为“xxxx”)分开,但数字是可变长度的。
我怀疑我需要在 sort() 函数中使用一些正则表达式并按空格分割数字然后对其进行排序,但我不知道如何配合字母排序。任何代码示例?非常感谢!
不需要 RegEx,因为Array.sort()
接受自定义函数:
var arr=["2 xxx","20 axxx","38 xxxx","20 bx","8540 xxxxxx"];
arr.sort(function(a,b){
a=a.split(" ");
b=b.split(" ");
var an=parseInt(a[0],10);
var bn=parseInt(b[0],10);
return an<bn?1:(an>bn?-1:(a[1]<b[1]?-1:(a[1]>b[1]?1:0)));
});
console.log(arr);
像这样的东西会起作用:
var arr = [
"2 xxx",
"20 axxx",
"38 xxxx",
"20 bx",
"8540 xxxxxx"
];
arr.sort(function(a, b) {
var aParts = a.split(" "),
bParts = b.split(" "),
aNum = +aParts[0], // convert numeric parts
bNum = +bParts[0]; // to actual numbers
if (aNum > bNum)
return -1;
else if (aNum < bNum)
return 1;
else
return aParts[1].localeCompare(bParts[1]);
});
演示:http: //jsfiddle.net/KLa2J/