JavaScript - 数组仅排序第一个字母/仅第一个数字

时间:2013-09-22 02:38:20

标签: javascript arrays sorting

我用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>");
    }
}

1 个答案:

答案 0 :(得分: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"]