0

我用 JavaScript 编写了一个程序,它收集用户的输入并按字母顺序或数字按字母数字排序。它使用数组并对该数组进行排序,但 JavaScript 仅按数字或单词中的第一个字符对其进行排序。因此,如果输入了 22、1 和 3,它将按 1、22、3 排序,因为它是按第一个字符排序的。单词也是如此。我将如何克服这一点?如果您认为我的代码可以帮助您告诉我如何操作,那么您就去吧。

var input = null;
var words = new Array();

function startApp()
{
    alert("Welcome to Word/Number Sorter 1.0");
    alert("Enter one word/number at a time in the next prompts. Enter passw0rd to finish/stop.");

    do {

        input = prompt("Enter word...enter passw0rd to exit.");
        if ( input != "passw0rd" ){
            words.push(input);
        }
        else{
            break;
        }
    }while( input != "passw0rd" );

    var newW = words.sort();

    for ( var i = 0; i < newW.length; i++ )
    {
        document.writeln(newW[i], "<br>");
    }
}
4

1 回答 1

1

要按数字排序,您需要一个特殊的排序回调:

[22,1,3].sort(function(a, b) { return a - b })
> [1, 3, 22]

如果你想要“自然排序”,它是这样的:

function natcmp(a, b) {
    var ra = a.match(/\D+|\d+/g);
    var rb = b.match(/\D+|\d+/g);
    var r = 0;

    while(!r && ra.length && rb.length) {
        var x = ra.shift(), y = rb.shift(),
            nx = parseInt(x), ny = parseInt(y);

        if(isNaN(nx) || isNaN(ny))
            r = x > y ? 1 : (x < y ? -1 : 0);
        else
            r = nx - ny;
    }
    return r || ra.length - rb.length;
}

ls = ['img35', 'img1', 'img2', 'img22', 'img3', 'img2.gif', 'foobar']
console.log(ls.sort(natcmp))

> ["foobar","img1","img2","img2.gif","img3","img22","img35"]
于 2013-09-22T02:41:41.367 回答