对json排序重组,如何用category.id重组(分类显示出来)

json代码如下:


var dat = {
    "data": [
    {
        "id": 2,
        "seller_id": 1,
        "name": "麻婆豆腐",
        "category": {
            "id": 1,
            "seller_id": 1,
            "name": "厨师推荐"
        }
    },
    {
        "id": 1,
        "seller_id": 1,
        "name": "回锅肉",
        "category": {
            "id": 2,
            "seller_id": 1,
            "name": "店长推荐"
        }
    },
    {
        "id": 3,
        "seller_id": 1,
        "name": "干锅鸡",
        "shopping_num": 1,
        "category": {
            "id": 2,
            "seller_id": 1,
            "name": "店长推荐"
        }
    },
    {
        "id": 6,
        "seller_id": 1,
        "name": "油炸虾子",
        "category": {
            "id": 3,
            "seller_id": 1,
            "name": "招牌菜"
        }
    },
    {
        "id": 7,
        "seller_id": 1,
        "name": "碳烤火鸡",
        "category": {
            "id": 1,
            "seller_id": 1,
            "name": "海鲜"
        }
    }
]
}

category.id 或category.name 重组数据 做到数据分类显示
显示视图:
图片描述

阅读 4.1k
3 个回答

用reduce,直接遍历,然后查找合并就好了。。。感觉是在帮你做作业。。。

function transform(data){
  return data.reduce((prev, item)=>{
    let id = item.category.id;

    if(prev[id]) {
      prev[id].items.push(item);
    } else {
      let { seller_id, name } = item.category;
      prev[id] = {
        seller_id,
        name,
        id,
        items: [item]
      }
    }

    return prev;
  }, {});
}

transform(data.data);

输出的时这个样子:

clipboard.png

直接按照分类过滤下就可以了,这个不是很清楚么,一定要把数组重组进行显示?

使用underscoregroupBy就可以啦:

var _ = require("underscore");

// 按照category.id重组 
var result = _.groupBy(dat.data, function(item){ return item.category.id; });


// 按照category.name重组 
var result = _.groupBy(dat.data, function(item){ return item.category.name; });
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题