• JS对象数组按照属性值排序并获取最大/小值


    let list = [ { name: "a1", data: 1}, { name: "a6", data: 6}, { name: "a2", data: 2}, { name: "a8", data: 8}, { name: "a4", data: 4}, { name: "a3", data: 3}, { name: "a7", data: 7}, { name: "a5", data: 5} ]

    console.log("list_____", list);

    // 方案一 根据某个属性值排序,然后根据索引获取

    function compare(prop) { return function (a, b) {

       let v1 = a[prop]; let v2 = b[prop];

       // 从小到大

       return v1 - v2;

     // 从大到小

      return v2 - v1;

      };

    }

    list.sort(compare("data")); console.log("list_____", list);

    // 方案二 根据某个属性值排序,然后根据索引获取

    // 从大到小

    list.sort((a, b) => { return b.data - a.data });

    console.log("list_____", list);

    // 从小到大

    list.sort((a, b) => { return a.data - b.data });

     console.log("list_____", list);

    // ES6真香警告 获取对象数组中属性值的最大/小值

    let arry = list.map(x => x.data);

    let arrystr = ...arry;

    // 最大值

    let max = Math.max(arrystr);

    // 最小值

    let min = Math.min(arrystr);

    // 以上合并成一行代码

    let result = Math.max(...list.map(x => x.data));

  • 相关阅读:
    Uva 12166 Equilibrium Mobile
    2015年7月实习经历以及一些感悟
    让键盘只数字键盘
    保留两位小数且,不四舍五入
    vuex的理解
    点击出现闪烁
    vue 添加样式分几种方法
    数据滞后的坑
    H5防止安卓手机软键盘弹出挤压页面导致变形的方法
    js 为false的几种情况
  • 原文地址:https://www.cnblogs.com/web-chuanfa/p/13163333.html
Copyright © 2020-2023  润新知