在Chrome浏览器中排序字符串时如何使用localeCompare?

时间:2012-04-08 08:45:57

标签: javascript sorting

例如,chineseName.sort((function(a,b){return a.localeCompare(b)})); javascript函数localeCompare适用于IE和Firefox,但不适用于Chrome。 任何人都知道如何使代码与Chrome兼容?

2 个答案:

答案 0 :(得分:0)

我只是搜索整个www来找到答案,但没有什么......所以我制作了自己的代码。它适用于丹麦语字母,因此对您来说可能不值得,但也许有其他人来寻找答案。这是我对问题的第一个回答,所以要温柔......

转换函数:转换函数是将'double-a'(丹麦语)[aa]转换为丹麦字母[å]。这样可以更轻松地逐个字符地进行比较。

danishCompareCharacter函数:该函数是实际的比较函数。它适用于特定的丹麦人物'æ','ø'和'å',它们位于丹麦alfabet的末尾。

danishCompareString函数:哪个是自定义排序函数,用作javascript排序函数中的参数。

function convert(stringToConvert)
{
    var returnString = new String();
    var tempLetter;
    for (var j = 0; j < stringToConvert.length; j++)
        {
            if (stringToConvert.toLowerCase()[j] == 'a' &&         stringToConvert.toLowerCase()[j + 1] == 'a')
                {
                    tempLetter = 'å';
                    j++;
                } else
                {
                    tempLetter = stringToConvert.toLowerCase()[j];

                }
            returnString = returnString + tempLetter;
        }
    return returnString;
}

function danishCompareCharacter(firstCharacter, secondCharacter) {
    if ((firstCharacter == 'æ') || (firstCharacter == 'ø') || (firstCharacter == 'å')) {
            if (secondCharacter == 'æ' || secondCharacter == 'ø' || secondCharacter == 'å') {
                    if (firstCharacter == secondCharacter) {
                            return 0;
                        } 
                        if ((firstCharacter == 'æ') || secondCharacter == 'å')
                                {
                                    return -1;
                                }
                            if ((firstCharacter == 'å') || secondCharacter == 'æ') {
                                    return 1;
                                }
                            }
                return 1;
            } 
    if (secondCharacter == 'æ' || secondCharacter == 'ø' || secondCharacter == 'å') {
            return -1;
        }
        if(firstCharacter==secondCharacter){
                return 0;}
    if( firstCharacter < secondCharacter)
        {
            return -1;
        } 
        return 1;
}

function danishCompareString(a, b)
{
    var result = 0;
    var length = b.length;
    if (a.length < b.length)
        {
            length = a.length;
        }
    for (var i = 0; i < length; i++) {
            result = danishCompareCharacter(a[i], b[i]);
            if (result != 0)
                {
                    return result;
                } 
            }
    return result;
}

function SortMyArray(arr) {
//This works in ALL browsers
arr.sort(function (a, b) {
    return (danishCompareString(convert(a[0]), convert(b[0])));

    //And this would have worked in any browser BUT chrome...
    //        if (a[0].localeCompare(b[0]) == 0) { return 0; }
    //        if (a[0].localeCompare(b[0]) < 0) { return -1; }
    //        else { return 1; }
});
}
}

答案 1 :(得分:0)

它现在在Chrome中运行得很好(5年后)。

由于您提到了中文名称,因此对中文名称数组进行排序的功能将是:

chineseNames.sort(function (a, b) {
  return a.localeCompare(b, 'zh-CN');
});

在ES2015中,它将是:

chineseNames.sort((a, b) => a.localeCompare(b, 'zh-CN'));

有关其他语言标识符,请参阅http://www.i18nguy.com/unicode/language-identifiers.html