当前位置 主页 > 网站技术 > 代码类 >

    JS实现json数组排序操作实例分析

    栏目:代码类 时间:2019-10-28 12:06

    本文实例讲述了JS实现json数组排序操作。分享给大家供大家参考,具体如下:

    有时需要根据json对象的某个属性排序json数组,javascript端有sort这个函数,具体可以参考:http://www.w3school.com.cn/jsref/jsref_sort.asp

    我们可以传入一个对比函数,我实现了两个:一个降序排列,一个升序排列

    /**
     * json对象数组按照某个属性排序:降序排列
     * @param {Object} propertyName
     */
    function compareDesc(propertyName) {
      return function(object1, object2) {
        var value1 = object1[propertyName];
        var value2 = object2[propertyName];
        if(value2 < value1) {
          return -1;
        } else if(value2 > value1) {
          return 1;
        } else {
          return 0;
        }
      }
    }
    /**
     * json对象数组按照某个属性排序:升序排列
     * @param {Object} propertyName
     */
    function compareAsc(propertyName) {
      return function(object1, object2) {
        var value1 = object1[propertyName];
        var value2 = object2[propertyName];
        if(value2 < value1) {
          return 1;
        } else if(value2 > value1) {
          return -1;
        } else {
          return 0;
        }
      }
    }
    
    

    例子:

    var students=[{name:"hhhh",age:16},{name:"ggggg",age:17},{name:"dsdsad",age:18}];
    students.sort(compareDesc("age"));  //按照年龄降序排列
    console.log(students);
    
    

    运行结果:

    var students=[{name:"hhhh",age:16},{name:"ggggg",age:17},{name:"dsdsad",age:18}];
    students.sort(compareAsc("age"));  //按照年龄升序排列
    console.log(students);
    
    

    运行结果:

    PS:关于json操作,这里再为大家推荐几款比较实用的json在线工具供大家参考使用:

    在线JSON代码检验、检验、美化、格式化工具:
    http://tools.jb51.net/code/json

    JSON在线格式化工具:
    http://tools.jb51.net/code/jsonformat

    在线XML/JSON互相转换工具:
    http://tools.jb51.net/code/xmljson

    json代码在线格式化/美化/压缩/编辑/转换工具:
    http://tools.jb51.net/code/jsoncodeformat

    在线json压缩/转义工具:
    http://tools.jb51.net/code/json_yasuo_trans

    更多关于JavaScript相关内容可查看本站专题:《JavaScript中json操作技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

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