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 相关文章推荐
jquery实现的让超出显示范围外的导航自动固定屏幕最顶上
Sep 22 Javascript
JavaScript中this的使用详解
Nov 08 Javascript
ajax读取数据后使用jqchart显示图表的方法
Jun 10 Javascript
异步JS框架的作用以及实现方法
Oct 29 Javascript
JS实现table表格数据排序功能(可支持动态数据+分页效果)
May 26 Javascript
jQuery移动端图片上传组件
Jun 12 Javascript
JS按钮闪烁功能的实现代码
Jul 21 Javascript
Vue 创建组件的两种方法小结(必看)
Feb 23 Javascript
详解vue 单页应用(spa)前端路由实现原理
Apr 04 Javascript
jQuery实现的鼠标拖动浮层功能示例【拖动div等任何标签】
Dec 29 jQuery
Vue表单控件绑定图文详解
Feb 11 Javascript
Vue2.0+Vux搭建一个完整的移动webApp项目的示例
Mar 19 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实现base64图片上传方式实例代码
2017/02/22 PHP
解决form中action属性后面?传递参数 获取不到的问题
2017/07/21 PHP
PHP清除缓存的几种方法总结
2017/09/12 PHP
laravel 出现command not found问题的解决方案
2019/10/23 PHP
jQuery中创建实例与原型继承揭秘
2011/12/21 Javascript
JQuery each打印JS对象的方法
2013/11/13 Javascript
jQuery读取和设定KindEditor值的方法
2013/11/22 Javascript
JS实现在页面随时自定义背景颜色的方法
2015/02/27 Javascript
AngularJS 日期格式化详解
2015/12/23 Javascript
JS结合bootstrap实现基本的增删改查功能
2016/07/22 Javascript
javascript数组遍历的方法实例分析
2016/09/13 Javascript
AngularJS 异步解决实现方法
2017/06/12 Javascript
Angular2.js实现表单验证详解
2017/06/23 Javascript
vue-cli的eslint相关用法
2017/09/29 Javascript
Vuejs中使用markdown服务器端渲染的示例
2017/11/22 Javascript
微信小程序局部刷新触发整页刷新效果的实现代码
2018/11/21 Javascript
小程序点击图片实现自动播放视频
2020/05/29 Javascript
vue+web端仿微信网页版聊天室功能
2019/04/30 Javascript
[03:36]2014DOTA2 TI小组赛综述 八强诞生进军钥匙球馆
2014/07/15 DOTA
[01:35]辉夜杯战队访谈宣传片—iG.V
2015/12/25 DOTA
[01:14:19]NAVI vs Mineski 2019国际邀请赛淘汰赛 败者组BO1 8.20.mp4
2020/07/19 DOTA
python with statement 进行文件操作指南
2014/08/22 Python
python编写的最短路径算法
2015/03/25 Python
详解PyTorch手写数字识别(MNIST数据集)
2019/08/16 Python
Python变量、数据类型、数据类型转换相关函数用法实例详解
2020/01/09 Python
浅谈移动端网页图片预加载方案
2018/11/05 HTML / CSS
捷克厨房用品购物网站:Tescoma
2018/07/13 全球购物
美国汽车零部件和配件网站:CarParts
2019/03/13 全球购物
幼师专业求职推荐信
2013/11/08 职场文书
道德之星事迹材料
2014/05/03 职场文书
热门专业求职信
2014/05/24 职场文书
上党课的心得体会
2014/09/02 职场文书
2014年营业员工作总结
2014/11/18 职场文书
2015年酒店年度工作总结
2015/05/23 职场文书
红十字会救护培训简讯
2015/07/20 职场文书
2015年入党积极分子培养考察意见
2015/08/12 职场文书