JS深入学习之数组对象排序操作示例


Posted in Javascript onMay 01, 2020

本文实例讲述了JS深入学习之数组对象排序功能。分享给大家供大家参考,具体如下:

JavaScript实现多维数组、对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序。

sort() 方法用于对数组的元素进行排序。语法如下:

arrayObject.sort(sortby)

返回值为对数组的引用。请注意,数组在原数组上进行排序,不生成副本。

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。
function NumAscSort(a,b)
{
 return a - b;
}
function NumDescSort(a,b)
{
 return b - a;
}
var arr = new Array( 3600, 5010, 10100, 801); 
arr.sort(NumDescSort);
alert(arr);
arr.sort(NumAscSort);
alert(arr);

sort(fun)接受了个排序规则函数,这个函数将比较2个数字的大小。而我们的对象数组排序,实际上原理也是一样的。

如果不比较数字的大小,则可以这样:

var myarray=["Apple", "Banana", "Orange"]
myarray.sort()

数组直接调用sort()后,数组按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。

对于对象数组排序,我们先写一个构造比较函数的函数:

//by函数接受一个成员名字符串做为参数
//并返回一个可以用来对包含该成员的对象数组进行排序的比较函数
var by = function(name){
 return function(o, p){
  var a, b;
  if (typeof o === "object" && typeof p === "object" && o && p) {
   a = o[name];
   b = p[name];
   if (a === b) {
    return 0;
   }
   if (typeof a === typeof b) {
    return a < b ? -1 : 1;
   }
   return typeof a < typeof b ? -1 : 1;
  }
  else {
   throw ("error");
  }
 }
}

要排序的数组:

var employees=[]
employees[0]={name:"George", age:32, retiredate:"March 12, 2014"}
employees[1]={name:"Edward", age:17, retiredate:"June 2, 2023"}
employees[2]={name:"Christine", age:58, retiredate:"December 20, 2036"}
employees[3]={name:"Sarah", age:62, retiredate:"April 30, 2020"}

直接调用函数:

employees.sort(by("age"));

到这里,对象数组排序就算基本实现了。那如何实现多个键值排序呢?意思就是先是对age排序,如果age相同,再比较name。

这时,我们可以进一步修改by函数,让其可以接受第二个参数,当主要的键值产生一个匹配的时候,另一个compare方法将被调用以决出高下。

//by函数接受一个成员名字符串和一个可选的次要比较函数做为参数
//并返回一个可以用来包含该成员的对象数组进行排序的比较函数
//当o[age] 和 p[age] 相等时,次要比较函数被用来决出高下
var by = function(name,minor){
 return function(o,p){
  var a,b;
  if(o && p && typeof o === 'object' && typeof p ==='object'){
   a = o[name];
   b = p[name];
   if(a === b){
    return typeof minor === 'function' ? minor(o,p):0;
   }
   if(typeof a === typeof b){
    return a < b ? -1:1;
   }
   return typeof a < typeof b ? -1 : 1;
  }else{
   thro("error");
  }
 }
}
employees.sort(by('age',by('name')));

好了,现在可以放心使用了。如果看不懂,可直接copy 这个by函数到你的应用里面,直接调用即可。

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

Javascript 相关文章推荐
利用jQuery 实现GridView异步排序、分页的代码
Feb 06 Javascript
caller和callee的区别介绍及演示结果
Mar 10 Javascript
Node.js中AES加密和其它语言不一致问题解决办法
Mar 10 Javascript
使用node.js 获取客户端信息代码分享
Nov 26 Javascript
快速学习jQuery插件 jquery.validate.js表单验证插件使用方法
Dec 01 Javascript
Vue.js每天必学之计算属性computed与$watch
Sep 05 Javascript
详解vue-Resource(与后端数据交互)
Jan 16 Javascript
实现两个文本框同时输入的实例
Sep 25 Javascript
基于es6三点运算符的使用方法(实例讲解)
Oct 12 Javascript
初识 Vue.js 中的 *.Vue文件
Nov 22 Javascript
vue-cli3 karma单元测试的实现
Jan 18 Javascript
Vue render函数实战之实现tabs选项卡组件
Apr 22 Javascript
vue 输入电话号码自动按3-4-4分割功能的实现代码
Apr 30 #Javascript
浅谈Vue3.0新版API之composition-api入坑指南
Apr 30 #Javascript
JavaScript变量Dom对象的所有属性
Apr 30 #Javascript
vue项目中使用bpmn为节点添加颜色的方法
Apr 30 #Javascript
VSCode搭建Vue项目的方法
Apr 30 #Javascript
jQuery实现的解析本地 XML 文档操作示例
Apr 30 #jQuery
vue使用map代替Aarry数组循环遍历的方法
Apr 30 #Javascript
You might like
PHP日期处理函数 整型日期格式
2011/01/12 PHP
EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
2017/04/04 PHP
django中的ajax组件教程详解
2018/10/18 PHP
PHP crc32()函数讲解
2019/02/14 PHP
Thinkphp 3.2框架使用Redis的方法详解
2019/10/24 PHP
DOM精简教程
2006/10/03 Javascript
js用图作提交按钮或超连接
2008/03/26 Javascript
JQuery入门——事件切换之hover()方法应用介绍
2013/02/05 Javascript
用js调用迅雷下载代码的二种方法
2013/04/15 Javascript
JS操作图片(增,删,改) 例子
2013/04/17 Javascript
Js查找字符串中出现次数最多的字符及个数实例解析
2016/09/05 Javascript
js实现点击图片自动提交action的简单方法
2016/10/16 Javascript
JavaScript中this的用法及this在不同应用场景的作用解析
2017/04/13 Javascript
JAVA中截取字符串substring用法详解
2017/04/14 Javascript
浅谈Vue SSR 的 Cookies 问题
2017/11/20 Javascript
bootstrap表格内容过长时用省略号表示的解决方法
2017/11/21 Javascript
Vue项目使用CDN优化首屏加载问题
2018/04/01 Javascript
在小程序开发中使用npm的方法
2018/10/17 Javascript
layui固定下拉框的显示条数(有滚动条)的方法
2019/09/10 Javascript
es6函数之箭头函数用法实例详解
2020/04/25 Javascript
Python中你应该知道的一些内置函数
2017/03/31 Python
Python设计模式之命令模式简单示例
2018/01/10 Python
python实现远程控制电脑
2019/05/23 Python
h5页面唤起app如果没安装就跳转下载(iOS和Android)
2020/06/03 HTML / CSS
美国男士和女士奢侈品折扣手表购物网站:Certified Watch Store
2018/06/13 全球购物
以工厂直接定价的传奇性能:Ben Hogan Golf
2019/01/04 全球购物
文件中有一组整数,要求排序后输出到另一个文件中
2012/01/04 面试题
静态成员和非静态成员的区别
2012/05/12 面试题
新兵入伍心得体会
2014/09/04 职场文书
埃及王子观后感
2015/06/16 职场文书
观后感开头
2015/06/19 职场文书
社区服务理念口号
2015/12/25 职场文书
2016优秀班主任个人先进事迹材料
2016/02/26 职场文书
2016年党员干部廉政承诺书
2016/03/24 职场文书
MySQL 数据类型选择原则
2021/05/27 MySQL
Python进程池与进程锁之语法学习
2022/04/11 Python