利用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 相关文章推荐
javascript学习笔记(十六) 系统对话框(alert、confirm、prompt)
Jun 20 Javascript
玩转方法:call和apply
May 08 Javascript
JavaScript中的原型和继承详解(图文)
Jul 18 Javascript
vue.js实现标签页切换效果
Jun 07 Javascript
webpack分离css单独打包的方法
Jun 12 Javascript
Vue+Webpack完美整合富文本编辑器TinyMce的方法
Nov 30 Javascript
javascript中floor使用方法总结
Feb 02 Javascript
微信小程序性能优化之checkSession的使用
Mar 06 Javascript
详解element-ui中表单验证的三种方式
Sep 18 Javascript
js数组中去除重复值的几种方法
Aug 03 Javascript
微信小程序 WeUI扩展组件库的入门教程
Apr 21 Javascript
Vue OpenLayer 为地图绘制风场效果
Apr 24 Vue.js
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不用第三变量交换2个变量的值的解决方法
2013/06/02 PHP
深入理解PHP内核(一)
2015/11/10 PHP
Yii框架创建cronjob定时任务的方法分析
2017/05/23 PHP
js静态作用域的功能。
2006/12/25 Javascript
用Jquery实现可编辑表格并用AJAX提交到服务器修改数据
2009/12/27 Javascript
jquery getScript动态加载JS方法改进详解
2012/11/15 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
JS快速实现移动端拼图游戏
2016/09/05 Javascript
基于iscroll.js实现下拉刷新和上拉加载效果
2016/11/28 Javascript
详谈js中window.location.search的用法和作用
2017/02/13 Javascript
一个可复用的vue分页组件
2017/05/15 Javascript
js 原生判断内容区域是否滚动到底部的实例代码
2017/11/15 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
2018/06/14 Javascript
vue webpack打包后图片路径错误的完美解决方法
2018/12/07 Javascript
Vue 3.0 全家桶抢先体验
2020/04/28 Javascript
python网络编程之UDP通信实例(含服务器端、客户端、UDP广播例子)
2014/04/25 Python
实例讲解Python编程中@property装饰器的用法
2016/06/20 Python
详解Python多线程
2016/11/14 Python
python 计算文件的md5值实例
2017/01/13 Python
Django中的Signal代码详解
2018/02/05 Python
python随机取list中的元素方法
2018/04/08 Python
解决Python的str强转int时遇到的问题
2018/04/09 Python
python实现的按要求生成手机号功能示例
2019/10/08 Python
解决numpy矩阵相减出现的负值自动转正值的问题
2020/06/03 Python
python 安装移动复制第三方库操作
2020/07/13 Python
W3C公布最新的HTML5标准草案
2008/10/17 HTML / CSS
行政主管岗位职责
2013/11/18 职场文书
两年的个人工作自我评价
2014/01/10 职场文书
《鸟岛》教学反思
2014/04/26 职场文书
企业年度评优方案
2014/06/02 职场文书
小学生国庆演讲稿
2014/09/05 职场文书
环卫工作汇报材料
2014/10/28 职场文书
英文邀请函
2015/02/02 职场文书
建党伟业观后感
2015/06/01 职场文书
Python的flask接收前台的ajax的post数据和get数据的方法
2021/04/12 Python
python中使用 unittest.TestCase单元测试的用例详解
2021/08/30 Python