javascript - 对json排序重组,如何用category.id重组(分类显示出来)
伊谢尔伦
伊谢尔伦 2017-04-11 11:22:44
[JavaScript讨论组]

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

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(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);

输出的时这个样子:

ringa_lee

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

PHP中文网

使用underscore的groupBy就可以啦:

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; });
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号