原文链接:https://blog.csdn.net/qq_37936542/article/details/78979521

js原生的 sort() 排序函数使用起来很方便

语法:arrayObject.sort(fun)       数组对象.sort(排序函数)

如果调用该方法时没有使用参数,将按照字符编码的顺序进行排序。也可以提供一个比较函数

作为参数,实现大小的排序。

例一:对数值型元素的数组进行大小排序

  1. //定义一个比较函数
  2. //升序排序
  3. function NumAscSort(a,b)
  4. {
  5. return a - b;
  6. }
  7. //降序排序
  8. function NumDescSort(a,b)
  9. {
  10. return b - a;
  11. }
  12. //定义数组
  13. var arr = new Array( 10, 30, 15, 45, 8);
  14. //对数组进行升序排序
  15. arr.sort(NumAscSort);
  16. alert(arr);
  17. //对数组进行降序排序
  18. arr.sort(NumDescSort);
  19. alert(arr);

例二:对字符串类型元素数组进行排序

  1. //当调用sort函数没有给予参数时,默认根据字符编码的顺序进行排序
  2. var arr = ["Apple", "Banana", "Orange"];
  3. arr.sort();
  4. alert(arr);

例三:对象数组排序

  1. //定义compare函数,参数name是对象的某一个属性,比如age、salary
  2. //返回一个可以用来对包含该成员的对象数组进行排序的比较函数
  3. var compare = function(name){
  4. return function(o, p){
  5. var a, b;
  6. if (typeof o === "object" && typeof p === "object" && o && p) {
  7. a = o[name];
  8. b = p[name];
  9. if (a === b) {
  10. return 0;
  11. }
  12. if (typeof a === typeof b) {
  13. return a < b ? -1 : 1;
  14. }
  15. return typeof a < typeof b ? -1 : 1;
  16. }
  17. else {
  18. throw ("error");
  19. }
  20. }
  21. }
  22. //定义员工对象数组
  23. var emp=[];
  24. emp[0]={name:"xiaoming", age:32, salary:11000};
  25. emp[1]={name:"xiaohong", age:17, salary:23000};
  26. emp[2]={name:"dahuang", age:58, salary:9000};
  27. emp[3]={name:"dajiji", age:62, salary:15000};
  28. <span style="white-space:pre">          </span>
  29. <span style="white-space:pre">          </span>
  30. //排序
  31. emp.sort(compare("age"));
  32. <span style="white-space:pre">  </span>
  33. for(var i = 0;i<emp.length; i++){
  34. alert(emp[i].age)
  35. }

例四:根据多个属性对 ‘对象数组’ 进行排序

  1. //定义compare函数,name是对象的某一个属性,fun是一个比较函数
  2. var compare = function(name,fun){
  3. return function(o,p){
  4. var a,b;
  5. if(o && p && typeof o === 'object' && typeof p ==='object'){
  6. a = o[name];
  7. b = p[name];
  8. //当o[name] 和 p[name] 相等时,利用fun函数根据另一个属性来进行比较
  9. if(a === b){
  10. return typeof minor === 'function' ? fun(o,p):0;
  11. }
  12. if(typeof a === typeof b){
  13. return a < b ? -1:1;
  14. }
  15. return typeof a < typeof b ? -1 : 1;
  16. }else{
  17. thro("error");
  18. }
  19. }
  20. }
  21. //定义员工对象数组
  22. var emp=[];
  23. emp[0]={name:"xiaoming", age:32, salary:11000};
  24. emp[1]={name:"xiaohong", age:62, salary:23000};
  25. emp[2]={name:"dahuang", age:58, salary:9000};
  26. emp[3]={name:"dajiji", age:62, salary:15000};
  27. //先根据age排序,age相等时,根据工资排序
  28. emp.sort(compare('age',compare('salary')));
  29. <span style="white-space:pre">      </span>
  30. for(var i = 0;i<emp.length; i++){
  31. <span style="white-space:pre">  </span>alert(emp[i].name)
  32. }

文末福利:

福利一:前端,Java,产品经理,微信小程序,Python等10G资源合集大放送:https://www.jianshu.com/p/e8197d4d9880

福利二:微信小程序入门与实战全套详细视频教程

【领取方法】

关注 【编程微刊】微信公众号:

回复【小程序demo】一键领取130个微信小程序源码demo资源。

回复【领取资源】一键领取前端,Java,产品经理,微信小程序,Python等资源合集10G资源大放送。



原文作者:祈澈姑娘
原文链接:https://www.jianshu.com/u/05f416aefbe1
创作不易,转载请告知

90后前端妹子,爱编程,爱运营,爱折腾。
坚持总结工作中遇到的技术问题,坚持记录工作中所所思所见,欢迎大家一起探讨交流。

Js数组排序函数:sort()的更多相关文章

  1. Js数组排序函数sort()

    JS实现多维数组和对象数组排序,用的其实就是原生sort()函数,语法为:arrayObject.sort(sortby)(sortby 可选.规定排序顺序.必须是函数.) 返回值为对数组的引用:请注 ...

  2. 深入探讨JS中的数组排序函数sort()和reverse()

    最近在研究Javascript发现了其中一些比较灵异的事情.有点让人感到无语比如: alert(typeof( NaN == NaN));//结果为假. alert(typeof( NaN != Na ...

  3. JS中的数组排序函数sort()

    JavaScript实现多维数组.对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序. sort() 方法用于对数组的元素进行排序.语法如下: arrayObject.sort ...

  4. PHP数组排序函数有哪些

    PHP数组排序函数有哪些 一.总结 一句话总结:其实也就是是否保持索引,对键排序还是对值排序,除了sort,rsort.shuffle,usort外,都是保持索引的 是否保持索引 键排序 值排序 除了 ...

  5. js数组排序 reverse()和sort()方法的使用

    WEB前端|js数组排序reverse()和sort()方法的使用,数组中已经存在两个可以直接用来重排序的方法:reverse()和sort(). reverse()方法会对反转数组项的顺序. var ...

  6. JS数组排序技巧汇总(冒泡、sort、快速、希尔等排序)

    本文实例总结了JS数组排序技巧.分享给大家供大家参考,具体如下: 1.冒泡排序 var temp = 0; for (var i = 0; i < array.length; i++) { fo ...

  7. js数组之sort排序的用法

    sort排序 转载自:https://blog.csdn.net/idomyway/article/details/80544509 js中用方法sort()为数组排序.sort()方法有一个可选参数 ...

  8. js 数组排序和算法排序

    1.算法排序 a.插入排序 var arr = [23,34,3,4,23,44,333,444]; var arrShow = (function insertionSort(array){ if( ...

  9. js数组排序

    在JS中,sort方法可用于数组的排序:先来看一个例子: var arr = [1, 2, 3, 5, 7, 78, 8, 89]; arr.sort(); console.log(arr); // ...

随机推荐

  1. uiautomator——第一个例子:打开浏览器,输入网址

    1.在sdk安装目录:E:\Test_Tools\auto_test\app\adt-bundle-windows-x86-20131030\sdk\tools下启动uiautomatorviewer ...

  2. bzoj3786星系探索(splay维护dfs序)

    Description 物理学家小C的研究正遇到某个瓶颈. 他正在研究的是一个星系,这个星系中有n个星球,其中有一个主星球(方便起见我们默认其为1号星球),其余的所有星球均有且仅有一个依赖星球.主星球 ...

  3. swift -结构体

    // // main.swift // Struct-Demo-05 // import Foundation println("结构体測试!") //结构体和C语言的结构体不同 ...

  4. SQL server 2012 安装SQL2012出现报错: 启用 Windows 功能 NetFx3 时出错

    在window server 2012服务器上,安装 SQL Server 2012的过程中,报了一个错误,一个安装失败, 在安装SQL 2012的过程中.出现下面错误:启用 Windows 功能 N ...

  5. android 4.4 添加物理按键

    kernel下添加 Linux-3.4/drivers/input/keyboard/Makefile linux-3.4/drivers/input/keyboard/sw-keyboard.c s ...

  6. [python]-类与对象-上

    [类]是一个函数包.类中可以放置函数和变量,然后类中的函数可以很方便的使用类中的变量 1.类的定义 2.类中方法的调用 在类中被定义的函数被称为类的[方法],描述的是这个类能做什么.我们使用类名.函数 ...

  7. app 自动化测试 Appium+python可以运行的代码

    Appium

  8. CMake - SWIG - 移植动态库

    CMake - SWIG 最后更新日期:2014-04-25 bykagula 阅读前提:<CMake入门(二)>.<同Java的混合编程-SWIG>.Linux的基本操作.j ...

  9. 下次自己主动登录(记住password)功能

    1:进入cookie插件 <script src="jquery.cookie.js" type="text/javascript"></sc ...

  10. iOS_06_Mac os X

    Mac os X 系统简介 * 苹果公司专门为苹果电脑设计的操作系统. * 以坚如磐石的UNIX为基础,既简单易用且功能强大. * x 是一个罗马数字正式的发音位“十”(ten),连续了先前的Mac ...