Home >Web Front-end >JS Tutorial >Detailed example of how JavaScript sorts Chinese characters

Detailed example of how JavaScript sorts Chinese characters

黄舟
黄舟Original
2017-06-18 11:47:572983browse

Sorting is a function we often encounter in daily development. The following article mainly introduces you to the relevant information about using JavaScript to sort Chinese (Chinese characters) , the article introduces it in detail through sample code, which has certain reference and learning value for everyone. Friends who need it can follow the editor to take a look.

Preface

When displaying a list on a web page, it is often necessary to sort the list: sort by modification/access time, by region, by name Sort.

For Chinese lists, sorting by name is sorting by pinyin, which cannot be achieved simply by string comparison - 'a' > 'b' - this way.

For example, comparing ‘Beijing’ vs ‘Shanghai’ actually compares ‘běijīng’ vs ‘shànghǎi’; comparing ‘Beijing’ vs ‘background’ actually compares ‘běijīng’ vs ‘bèijǐng’.

Generally, you need to obtain the pinyin of the string and then compare the respective pinyin.

Implementation method

JavaScript provides localized text sorting, such as sorting Chinese according to pinyin, without the need for the program to display the pinyin comparison string.

<a href="http://www.php.cn/wiki/57.html" target="_blank">String</a>.prototype.localeCompare Without considering polyphonic characters, sorting by pinyin can basically be achieved perfectly.

As long as there are no accidents, all browsers that support localeCompare are normal. Recently, I updated Chrome to 58.0.3029.110, and suddenly found that the Chinese sorting was not normal.


// 正常应该返回 1, 拼音 jia 在前, kai 在后
&#39;开&#39;.localeCompare(&#39;驾&#39;);
// 得到
-1;
 
// Chrome 58.0.3029.110 下返回 -1, 其他浏览器正常
 
// 确认之后是 localeCompare 需要明确指定 locales 参数
&#39;开&#39;.localeCompare(&#39;驾&#39;, &#39;zh&#39;);
// 得到
1


Pass the locales parameter under Chrome to obtain normal expected results

Edge browser supports localeCompare

Firefox browser supports localeCompare

IE 11 browser supports localeCompare

Other browsers are also very friendly to localeCompare support. Currently, there is no need to explicitly pass locales. For browser support, please refer to developer.mozilla.org

Summary

The above is the detailed content of Detailed example of how JavaScript sorts Chinese characters. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn