美文网首页
js使用Array.prototype.sort()对数组对象排

js使用Array.prototype.sort()对数组对象排

作者: Sraita | 来源:发表于2016-04-24 00:54 被阅读370次

这篇文章主要介绍了js使用Array.prototype.sort()对数组对象排序的方法,实例分析了Array.prototype.sort()的原理与相关的使用技巧,需要的朋友可以参考下

本文实例讲述了js使用Array.prototype.sort()对数组对象排序的方法。分享给大家供大家参考。具体分析如下:
在讲对数组对象进行排序时,我们先来简单的了解一下Array.prototype.sort()。sort方法接受一个参数——Function,function会提供两个参数,分别是两个进行比较的元素,如果元素是String类型则通过Unicode code进行比较,如果是Number类型则比较值的大小。如果比较的函数中返回1则两个元素交换位置,0和-1不交换位置。先看一个例子:

var arr = [3, 5, 2, 1];
// 从小到大排序
arr.sort(function (a, b) {    
  return a > b ? 1 : -1;
});
// 得到的结果:[1, 2, 3, 5]

那么回到我们的主题,如果是对一个数组对象进行排序,该怎么写呢?其实原理和上面一样,如:

var arr = [   
   { a : 2, b : 3.2},    
   { a : 3, b : 1.2},    
   { a : 4, b : 2.2},    
   { a : 6, b : 1.2},    
   { a : 5, b : 3.2}]
// 从小到大按属性b排序
arr.sort(function(x, y){    
  return x.b > y.b ? 1:-1;
});

x和y就是arr的一个元素,即一个对象,所以直接比较两个对象的属性即可。
上面的例子中,最小的元素中有重复,如果需求是:先按b属性从小到大排序,如果最小中有重复则再按a属性排序,那应该怎么写呢?
在排序的时候,先按b属性排序,如果x.b的大于y.b则将x移到y的右边,如果x.b等于y.b则再通过x.a和y.a进行比较,所以代码如下:

arr.sort(function (x, y) {    
  if (x.b > y.b) {        
    return 1;    
  } else if (x.b === y.b) {        
    return x.a > y.a ? 1 : -1;    
  } else if (x.b < y.b) {        
    return -1;    
  }
});

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

本文转载自:

《js使用Array.prototype.sort()对数组对象排序》,原文作者:shichen2014

相关文章

  • js使用Array.prototype.sort()对数组对象排

    这篇文章主要介绍了js使用Array.prototype.sort()对数组对象排序的方法,实例分析了Array....

  • JS或Jquery之遍历对象数组取出字符串用逗号拼接方式

    使用JS遍历对象数组方式一如下: 使用JS遍历数组方式二如下: 使用Jquery遍历对象数组如下:

  • JS数组以及数组变换

    有关数组 数组对象——一种特殊的对象JS其实没有数组,只使用对象来模拟数组 典型数组和JS数组的区别 典型数组 元...

  • js对象数组深度去重和深度排序

    js对象数组深度去重和深度排序 要点:使用collect.js处理数组和对象 https://github.com...

  • 在vue中使用样式

    直接使用数组 样式表 html和js 在数组中使用三元表达式 在数组中使用对象 使用对象的形式 如果对象的内容太长...

  • JS jsonArray操作

    JS jsonArray操作 js对数组对象的操作以及方法的使用 如何声明创建一个数组对象:var arr = n...

  • 前端charts常用小结

    图表插件 jquery插件使用举例: json数组 JS遍历json对象 或者 通过JS动态添加table的tr,...

  • 使用js传递数组对象

    在js中创建数组,数组中每一个元素是一个对象,实现:var imageList = new Array();lis...

  • 数组检测

    检测是否是数组: 数组转字符串: 字符串转换数组: js对象转换成js字符串: js字符串转换成js对象:

  • 归并排序

    背景 Array.prototype.sort的实现,不同浏览器有不同的算法实现 chrome使用的快排 Fire...

网友评论

      本文标题:js使用Array.prototype.sort()对数组对象排

      本文链接:https://www.haomeiwen.com/subject/aihfrttx.html