javascript - 使用lodash将数据分组

查看:108
本文介绍了javascript - 使用lodash将数据分组的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

希望高手给出快速分类数据的方法:

数据集合是:

{"mm37_160d_99_00.gif":"SH/DAzRtH4102.gif","mm37_160d_99_01.gif":"SH/DAzRtH42102.gif","mm37_160d_98_01.gif":"SH/DAzDuq6ik357.gif","mm89_160d_99_02.gif":"SH/DAzw583.gif"}

希望能用lodash的函数,将上面的数据集合分的更细如下:

{
    "37":{
        "99":{"mm37_160d_99_00.gif":"SH/DAzRtH4102.gif","mm37_160d_99_01.gif":"SH/DAzRtH42102.gif"},
        "98":{"mm37_160d_98_01.gif":"SH/DAzDuq6ik357.gif"}
    },
    "89":{
        "99":{"mm89_160d_99_02.gif":"SH/DAzw583.gif"}
    }
}

其中,分组依据"mm37_160d_99_00.gif":37是大类,99是小类
如果我格式写的不妥,给你造成了麻烦,十分抱歉。
如果您时间紧张,告诉我哪个函数合适,我自己来琢磨,也可以的。

解决方案

var obj = {"mm37_160d_99_00.gif":"SH/DAzRtH4102.gif","mm37_160d_99_01.gif":"SH/DAzRtH42102.gif","mm37_160d_98_01.gif":"SH/DAzDuq6ik357.gif","mm89_160d_99_02.gif":"SH/DAzw583.gif"};
function formatObj(obj){
    var keys = Object.keys(obj);
    var resultObj  = {};
    for (var i=0;i<keys.length;i++){
        var bigCategory = keys[i].slice(2,4);
        var smallCategory = keys[i].slice(10,12);
        resultObj[bigCategory] = Object.assign({},resultObj[bigCategory]);
        resultObj[bigCategory][smallCategory]= Object.assign({},resultObj[bigCategory][smallCategory]);
        resultObj[bigCategory][smallCategory][keys[i]] = obj[keys[i]];
        
    }
    return resultObj;
}   
    

这篇关于javascript - 使用lodash将数据分组的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆