按字符对javascript中的字符串进行排序

时间:2012-11-08 05:37:50

标签: javascript

我想在输入字符时对字符串列表进行排序。假设我有类似的字符串 “狗”,“球”,“兔子”,“披萨”等,当用户首先输入“d”时,“狗”应该出现“Ball”,然后“Pizza”,最后“Rabbit”应该显示。 / p>

如何实现此功能。请提供任何线索。

3 个答案:

答案 0 :(得分:0)

我认为您可以使用此代码。它没有优化,但你可以得到这个想法

    <script type="text/javascript">
function fnc()
{
    var arr=new Array;
    var arr1=new Array;
    arr[0]="dog";
    arr[1]="pizza";
    arr[2]="doll";
    for(i=0;i<arr.length;++i)
    {arr1[i]=arr[i].length;}

    arr1=arr1.sort();
    alert(arr1);
}
</script>
<input type="button" onclick="fnc()" />

答案 1 :(得分:0)

var reg = /^d/i;  //reg exp to check array item first char
['Pizza', 'Dog', 'Ball', 'Foo'].sort(
function(a, b) { 
    if (reg.test(a)) {
        if (reg.test(b)) 
            return a > b; 
        return -1;
    } 
    if (reg.test(b)) { 
        if (reg.test(a)) 
            return a > b;
        return 1; 
    } 
    return a > b; 
})

返回[“狗”,“球”,“Foo”,“披萨”]

答案 2 :(得分:0)

根据当前输入生成排序功能 如果当前输入与sort中的一个项匹配,则首先将其默认。如果它匹配两者或没有匹配正常的字符串。

function generateSortFunction(str){
    var s = str.toLowerCase(), sl = s.length; // save re-computation
    return function sort(a,b){
        var am = +( a.length >= sl && a.slice(0, sl).toLowerCase() === s ),
            bm = +( b.length >= sl && b.slice(0, sl).toLowerCase() === s );
        if( am ^ bm ) return bm - am; // XOR then -1 if a first, 1 if b first.
        return a.localeCompare(b); // else sort normally
    };
}

// Using it
["Dog", "Ball", "Rabbit", "Pizza"].sort( generateSortFunction('d') );
// results in ["Dog", "Ball", "Pizza", "Rabbit"]

上面的代码使用输入'd',根据需要进行修改。