JavaScript自定义数组排序方法


Posted in Javascript onFebruary 12, 2015

本文实例讲述了JavaScript自定义数组排序方法。分享给大家供大家参考。具体分析如下:

Array中有自带的排序功能,这个使用起来比较方便,我们有一点必须清楚,就是排序的依据,如果sort不传入参数的话,那就是按照字符编码(Unicode编码)的顺序排序。

var a=["3","2","1"]; 
console.log(a[0].charCodeAt(0)); // 51 
console.log(a[1].charCodeAt(0)); // 50 
console.log(a[2].charCodeAt(0)); // 49 
console.log(a.sort());      // ["1", "2", "3"] 
 
var a=["3","你","他"]; 
console.log(a[0].charCodeAt(0)); // 51 
console.log(a[1].charCodeAt(0)); // 20320 
console.log(a[2].charCodeAt(0)); // 20182 
console.log(a.sort());      // ["3", "他", "你"] 
 
var a=["3","11","222"]; 
console.log(a.sort());// ["11", "222", "3"]  
           // 多个字符的时候按照第一个字符的编码

不过我觉得sort最好用的地方在于可以自定义排序,这个在实际运用中也比较常见,比如要对对象数组排序。例如线面的一个对象数组,要根据其中的某一个字段进行排序,当然自己也可以写个函数来完成,不过我想没有sort来得方便。

var list = [ 
  { 
    max:3, 
    avg:2, 
    min:1 
  }, 
  { 
    max:10, 
    avg:15, 
    min:20 
  }, 
  { 
    max:8, 
    avg:5, 
    min:2 
  } 
]; 
// 根据max字段对list对象进行排序,从小到大的顺序 
// x,y就是要比较的数组的单个元素,这里就是list中的一个元素 
// 排序方法主要是要提供一个比较大小的规则,换句话说也就是要说明谁大谁小 
// 返回值为true or false 
function sortByField(x, y) { 
  return x.max - y.max; 
} 
console.log(list.sort(sortByField));

运行效果如下图所示:

JavaScript自定义数组排序方法

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
ASP小贴士/ASP Tips javascript tips可以当桌面
Dec 10 Javascript
从JQuery源码分析JavaScript函数的apply方法与call方法
Sep 25 Javascript
Javascript获取CSS伪元素属性的实现代码
Sep 28 Javascript
javascript通过获取html标签属性class实现多选项卡的方法
Jul 27 Javascript
js仿黑客帝国字母掉落效果代码分享
Nov 08 Javascript
js实现向右横向滑出的二级菜单效果
Aug 27 Javascript
基于AngularJS+HTML+Groovy实现登录功能
Feb 17 Javascript
自动完成的搜索框javascript实现
Feb 26 Javascript
JS中的forEach、$.each、map方法推荐
Apr 05 Javascript
jQuery实现checkbox的简单操作
Nov 18 jQuery
Vue.js 事件修饰符的使用教程
Nov 01 Javascript
Node使用Selenium进行前端自动化操作的代码实现
Oct 10 Javascript
zepto.js中tap事件阻止冒泡的实现方法
Feb 12 #Javascript
后台获取ZTREE选中节点的方法
Feb 12 #Javascript
在父页面得到zTree已选中的节点的方法
Feb 12 #Javascript
ztree获取当前选中节点子节点id集合的方法
Feb 12 #Javascript
javascript编写实用的省市选择器
Feb 12 #Javascript
jQuery遍历json中多个map的方法
Feb 12 #Javascript
javascript中call,apply,bind的用法对比分析
Feb 12 #Javascript
You might like
PHP创建自己的Composer包方法
2018/04/09 PHP
学习ExtJS Window常用方法
2009/10/07 Javascript
iframe的onload在Chrome/Opera中执行两次Bug的解决方法
2011/03/17 Javascript
分享10篇优秀的jQuery幻灯片制作教程及应用案例
2011/04/16 Javascript
javascript针对DOM的应用分析(三)
2012/04/15 Javascript
基于jquery插件实现常见的幻灯片效果
2013/11/01 Javascript
深入理解jQuery中live与bind方法的区别
2013/12/18 Javascript
jQuery中验证表单提交方式及序列化表单内容的实现
2014/01/06 Javascript
18个非常棒的jQuery代码片段
2015/11/02 Javascript
js实现的星星评分功能函数
2015/12/09 Javascript
浅谈layui里的上传控件问题
2019/09/26 Javascript
vue+elementUI动态增加表单项并添加验证的代码详解
2020/12/17 Vue.js
vite2.0+vue3移动端项目实战详解
2021/03/03 Vue.js
[57:36]DOTA2-DPC中国联赛 正赛 SAG vs CDEC BO3 第三场 2月1日
2021/03/11 DOTA
Python实现Tab自动补全和历史命令管理的方法
2015/03/12 Python
详解Python中的动态属性和特性
2018/04/07 Python
解决Pycharm中import时无法识别自己写的程序方法
2018/05/18 Python
使用python绘制二元函数图像的实例
2019/02/12 Python
python requests模拟登陆github的实现方法
2019/12/26 Python
Pytorch中Tensor与各种图像格式的相互转化详解
2019/12/26 Python
Python环境管理virtualenv&virtualenvwrapper的配置详解
2020/07/01 Python
Python绘制词云图之可视化神器pyecharts的方法
2021/02/23 Python
详解HTML5中的元素与元素
2015/08/17 HTML / CSS
浅谈html5标签css3的常用样式
2016/10/20 HTML / CSS
印度尼西亚手表和包包商店:Urban Icon
2019/12/12 全球购物
自荐书范文
2013/12/08 职场文书
回门宴答谢词
2014/01/13 职场文书
办公室员工岗位工作职责
2014/03/10 职场文书
职称评定自我鉴定
2014/03/18 职场文书
秋天的怀念教学反思
2014/04/28 职场文书
实验室的标语
2014/06/20 职场文书
毕业生代领毕业材料的授权委托书
2014/09/29 职场文书
党员教师四风自我剖析材料
2014/09/30 职场文书
教师查摆问题及整改措施
2014/10/11 职场文书
2014年材料员工作总结
2014/11/19 职场文书
2015年财务科工作总结范文
2015/05/13 职场文书