• JavaScript对象数组根据某属性sort升降序排序


    1、自定义一个比较器,其参数为待排序的属性。

    2、将带参数的比较器传入sort()。

    var data = [
        {name: "Bruce", age: 23, id: 16, score: 80},
        {name: "Alice", age: 24, id: 12, score: 90},
        {name: "David", age: 21, id: 11, score: 70},
        {name: "Cindy", age: 22, id: 10, score: 100},
    ];


    data.sort(compareUp("age"));
    data.sort(compareDown("age"));


    function compareUp(propertyName) { // 升序排序
            if ((typeof data[0][propertyName]) != "number") { // 属性值为非数字
                  return function(object1, object2) {
                      var value1 = object1[propertyName];
                      var value2 = object2[propertyName];
                     return value1.localeCompare(value2);
                 }
           } else {
                return function(object1, object2) { // 属性值为数字
                      var value1 = object1[propertyName];
                      var value2 = object2[propertyName];
                     return value1 - value2;
                 }
           }
    }


    function compareDown(propertyName) { // 降序排序
           if ((typeof data[0][propertyName]) != "number") { // 属性值为非数字
               return function(object1, object2) {
                    var value1 = object1[propertyName];
                    var value2 = object2[propertyName];
                    return value2.localeCompare(value1);
               }
       } else {
            return function(object1, object2) { // 属性值为数字
                  var value1 = object1[propertyName];
                  var value2 = object2[propertyName];
                  return value2 - value1;
            }
        }
    }

  • 相关阅读:
    Python(错误的处理方法)
    WP7 QQ词典V1.1 共享源代码
    【原创】Windows Phone真机抓包并分析应用程序的网络通讯(Android、iPhone也适用)
    使用uiautomation自动化重命名pdf书签,使全大写字母变成首字母大写
    分享python分析wave, pcm音频文件
    最近在做的一个wp7地图应用
    HTML5初探 基本的HTML5模版
    HTML5页面架构元素 <header>标签
    Wix 打包(1)[转载]
    windows 域验证 IIS7.0
  • 原文地址:https://www.cnblogs.com/ranyonsue/p/9687868.html
Copyright © 2020-2023  润新知