利用JavaScript对中文(汉字)进行排序实例详解


Posted in Javascript onJune 18, 2017

前言

在网页上展示列表时经常需要对列表进行排序:按照修改/访问时间排序、按照地区、按照名称排序。

对于中文列表按照名称排序就是按照拼音排序,不能简单通过字符串比较—— ‘a' > ‘b'——这种方式来实现。

比如比较 ‘北京' vs ‘上海',实际是比较 ‘běijīng' vs ‘shànghǎi';比较 ‘北京' vs ‘背景',实际是比较 ‘běijīng' vs ‘bèijǐng'。

一般需要获取到字符串的拼音,再比较各自的拼音。

实现方法

JavaScript 提供本地化文字排序,比如对中文按照拼音排序,不需要程序显示比较字符串拼音。

String.prototype.localeCompare 在不考虑多音字的前提下,基本可以完美实现按照拼音排序。

在没有出现意外的情况下,各个支持 localeCompare 的浏览器都很正常。最近将 Chrome 更新到 58.0.3029.110,突然发现中文排序不正常。

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

利用JavaScript对中文(汉字)进行排序实例详解

在 Chrome 下传递 locales 参数才能获得正常预期结果

利用JavaScript对中文(汉字)进行排序实例详解

Edge 浏览器支持 localeCompare

利用JavaScript对中文(汉字)进行排序实例详解

Firefox 浏览器支持 localeCompare

利用JavaScript对中文(汉字)进行排序实例详解

IE 11 浏览器支持 localeCompare

其他浏览器对 localeCompare 支持也很友好,目前也不需要明确传递 locales,浏览器支持参考 developer.mozilla.org

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
让jQuery与其他JavaScript库并存避免冲突的方法
Dec 23 Javascript
jquery自动填充勾选框即把勾选框打上true
Mar 24 Javascript
JavaScript函数参数使用带参数名的方式赋值传入的方法
Mar 19 Javascript
原生JavaScript编写俄罗斯方块
Mar 30 Javascript
jQuery实现产品对比功能附源码下载
Aug 09 Javascript
微信小程序 websocket 实现SpringMVC+Spring+Mybatis
Aug 04 Javascript
node-sass安装失败的原因与解决方法
Sep 04 Javascript
详解 vue better-scroll滚动插件排坑
Feb 08 Javascript
jQuery中的for循环var与let的区别
Apr 21 jQuery
vuex + axios 做登录验证 并且保存登录状态的实例
Sep 16 Javascript
js对象属性名驼峰式转下划线的实例代码
Sep 17 Javascript
Vue3.0的优化总结
Oct 16 Javascript
JavaScript ES6中const、let与var的对比详解
Jun 18 #Javascript
jquery DataTable实现前后台动态分页
Jun 17 #jQuery
jQuery Jsonp跨域模拟搜索引擎
Jun 17 #jQuery
vue router路由嵌套不显示问题的解决方法
Jun 17 #Javascript
详解vue+vueRouter+webpack的简单实例
Jun 17 #Javascript
js轮播图无缝滚动效果
Jun 17 #Javascript
详解webpack+vue-cli项目打包技巧
Jun 17 #Javascript
You might like
实例分析基于PHP微信网页获取用户信息
2017/11/24 PHP
JQuery的html(data)方法与<script>脚本块的解决方法
2010/03/09 Javascript
仿jQuery的siblings效果的js代码
2011/08/09 Javascript
javascript判断iphone/android手机横竖屏模式的函数
2011/12/20 Javascript
IE6下opacity与JQuery的奇妙结合
2013/03/01 Javascript
解析瀑布流布局:JS+绝对定位的实现
2013/05/08 Javascript
Jquery全选与反选点击执行一次的解决方案
2015/08/14 Javascript
jquery通过name属性取值的简单实现方法
2016/06/20 Javascript
详解AngularJS 路由 resolve用法
2017/04/24 Javascript
原生JS实现的碰撞检测功能示例
2018/05/18 Javascript
jquery实现动态添加附件功能
2018/10/23 jQuery
js序列化和反序列化的使用讲解
2019/01/19 Javascript
Openlayers显示瓦片网格信息的方法
2020/09/28 Javascript
ES5和ES6中类的区别总结
2020/12/21 Javascript
[10:34]DOTA2上海特级锦标赛全纪录
2016/03/25 DOTA
[01:19:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第二局
2016/03/05 DOTA
Python实现动态加载模块、类、函数的方法分析
2017/07/18 Python
理解Python中的绝对路径和相对路径
2017/08/30 Python
深入理解Python中的*重复运算符
2017/10/28 Python
postman模拟访问具有Session的post请求方法
2019/07/15 Python
Python一键安装全部依赖包的方法
2019/08/12 Python
解决pycharm中导入自己写的.py函数出错问题
2020/02/12 Python
基于Python模拟浏览器发送http请求
2020/11/06 Python
Charles & Colvard官网:美国莫桑石品牌
2019/06/05 全球购物
什么是反射?如何实现反射?
2016/07/25 面试题
自我评价范文
2013/12/22 职场文书
给交警的表扬信
2014/01/12 职场文书
水利公司纪检监察自我鉴定
2014/02/25 职场文书
保护环境建议书
2014/03/12 职场文书
应届生求职自荐信
2014/07/04 职场文书
2016入党培训心得体会范文
2016/01/08 职场文书
如何在Python中创建二叉树
2021/03/30 Python
查看nginx配置文件路径和资源文件路径的方法
2021/03/31 Servers
Mysql Online DDL的使用详解
2021/05/20 MySQL
【海涛教你打DOTA】剑圣第一人称视角解说
2022/04/01 DOTA
vue3语法糖内的defineProps及defineEmits
2022/04/14 Vue.js