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

发布于 2022-09-04 10:05:22 字数 1204 浏览 30 评论 0

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 重组数据 做到数据分类显示
显示视图:
图片描述

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

仅冇旳回忆 2022-09-11 10:05:23

用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

梦途 2022-09-11 10:05:23

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

夏末染殇 2022-09-11 10:05:23

使用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; });
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文