利用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 相关文章推荐
js window.open弹出新的网页窗口
Jan 16 Javascript
22点关于jquery性能优化的建议
May 28 Javascript
jQuery div拖拽用法实例
Jan 14 Javascript
Vue应用部署到服务器的正确方式
Jul 15 Javascript
requireJS模块化实现返回顶部功能的方法详解
Oct 16 Javascript
详解Vue 中 extend 、component 、mixins 、extends 的区别
Dec 20 Javascript
jquery实现企业定位式导航效果
Jan 01 jQuery
使用watch监听路由变化和watch监听对象的实例
Feb 24 Javascript
使用angularjs.foreach时return的问题解决
Sep 30 Javascript
详解vue如何使用rules对表单字段进行校验
Oct 17 Javascript
JS实现判断有效的数独算法示例
Feb 25 Javascript
vue-cli在 history模式下的配置详解
Nov 26 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 ADODB使用方法集锦
2008/03/25 PHP
PHP中$_SERVER的详细参数与说明
2008/07/29 PHP
php下实现在指定目录搜索指定类型文件的函数
2008/10/03 PHP
PHP及Zend Engine的线程安全模型分析
2011/11/10 PHP
php旋转图片90度的方法
2013/11/07 PHP
初识php MVC
2014/09/10 PHP
详解WordPress中提醒安装插件以及隐藏插件的功能实现
2015/12/25 PHP
Linux环境下php实现给网站截图的方法
2016/05/03 PHP
JS判断页面加载状态以及添加遮罩和缓冲动画的代码
2012/10/11 Javascript
js浮点数保留两位小数点示例代码(四舍五入)
2013/12/26 Javascript
javaScript使用EL表达式的几种方式
2014/05/27 Javascript
jQuery实现新消息在网页标题闪烁提示
2015/06/23 Javascript
node.js回调函数之阻塞调用与非阻塞调用
2015/11/13 Javascript
基于jquery实现省市区三级联动效果
2015/12/25 Javascript
JS组件Bootstrap实现下拉菜单效果代码
2016/04/26 Javascript
JavaScript中return用法示例
2016/11/29 Javascript
vue点击input弹出带搜索键盘并监听该元素的方法
2018/08/25 Javascript
解决一个微信号同时支持多个环境网页授权问题
2019/08/07 Javascript
vue router动态路由设置参数可选问题
2019/08/21 Javascript
vue实现表格过滤功能
2019/09/27 Javascript
Vue实现省市区三级联动
2020/12/27 Vue.js
[55:45]LGD vs OG 2019国际邀请赛淘汰赛 胜者组 BO3 第三场 8.24
2019/09/10 DOTA
Python程序设计入门(3)数组的使用
2014/06/16 Python
Python列表append和+的区别浅析
2015/02/02 Python
ubuntu16.04制作vim和python3的开发环境
2018/09/23 Python
关于Python 中的时间处理包datetime和arrow的方法详解
2020/03/19 Python
Python如何把Spark数据写入ElasticSearch
2020/04/18 Python
几个解决兼容IE6\7\8不支持html5标签的几个方法
2013/01/07 HTML / CSS
Original Penguin美国官网:布拉德皮特、强尼德普喜爱的服装品牌
2016/10/25 全球购物
法国在线药房:DoctiPharma
2020/10/21 全球购物
学习雷锋做美德少年寄语大全
2014/04/09 职场文书
三八活动策划方案
2014/08/17 职场文书
优秀学生干部事迹材料
2014/12/24 职场文书
读《皮囊》有感:理解是对他人的最大的善举
2019/11/14 职场文书
python 机器学习的标准化、归一化、正则化、离散化和白化
2021/04/16 Python
Python pandas之求和运算和非空值个数统计
2021/08/07 Python