zoukankan      html  css  js  c++  java
  • JavaScript中数组Array.sort()排序方法详解

    转载来自 https://www.jb51.net/article/107153.htm (同学们手动去浏览器控制面板里敲出代码,才能更好的理解掌握)

    JavaScript中数组的sort()方法主要用于对数组的元素进行排序。其中,sort()方法有一个可选参数。但是,此参数必须是函数。 数组在调用sort()方法时,如果没有传参将按字母顺序(字符编码顺序)对数组中的元素进行排序,如果想按照其他标准进行排序,就需要进行传一个参数且为函数,该函数要比较两个值,并且会返回一个用于说明这两个值的相对顺序的数字。

    1、对数字数组进行由小到大的顺序进行排序。

    代码:

    var arr = [22,12,3,43,56,47,4];
    arr.sort();
    console.log(arr); // [12, 22, 3, 4, 43, 47, 56]
    arr.sort(function (m, n) {
     if (m < n) return -1
     else if (m > n) return 1
     else return 0
    });
    console.log(arr); // [3, 4, 12, 22, 43, 47, 56]
     
    或者用第二个值减去第一个值
    var aa = [100,44,89,33,0]
    aa.sort();  //[0, 100, 33, 44, 89]
    aa.sort(function(v1,v2){ return v1-v2})  //[0, 33, 44, 89, 100]
     
    2、对字符串数组执行不区分大小写的字母表排序。
    var arr = ['abc', 'Def', 'BoC', 'FED'];
     
    console.log(arr.sort()); // ["BoC", "Def", "FED", "abc"]
    console.log(arr.sort(function(s, t){
    var a = s.toLowerCase();
     var b = t.toLowerCase();
     if (a < b) return -1;
     if (a > b) return 1;
     return 0;
    })); // ["abc", "BoC", "Def", "FED"]
     
    3、对包含对象的数组排序,要求根据对象中的年龄进行由大到小的顺序排列
    var arr = [{'name': '张三', age: 26},{'name': '李四', age: 12},{'name': '王五', age: 37},{'name': '赵六', age: 4}];
    var objectArraySort = function (keyName) {
     return function (objectN, objectM) {
      var valueN = objectN[keyName]
      var valueM = objectM[keyName]
      if (valueN < valueM) return 1
      else if (valueN > valueM) return -1
      else return 0
     }
    }
    arr.sort(objectArraySort('age'))
    console.log(arr) // [{'name': '王五', age: 37},{'name': '张三', age: 26},{'name': '李四', age: 12},{'name': '赵六', age: 4}]
     
  • 相关阅读:
    CentOS 7.3 系统安装配置图解教程
    图床神器:七牛云 + Mpic + FScapture
    Markdown 使用教程
    Python小游戏、小程序
    深入理解Python中的yield和send
    替代crontab,任务计划统一集中管理系统cronsun简介
    变量命名神器Codelf
    Spring Aspect实现AOP切面
    SpringCloud之注册中心Eureka搭建
    SpringCloud中eureka配置心跳和剔除下线的服务的时间
  • 原文地址:https://www.cnblogs.com/quxiajun/p/10535957.html
Copyright © 2011-2022 走看看