• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

go中的无限极分类的问题

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

最近在开发的过程中遇到一个无限极分类的问题,这种问题在php中写过很多,想着很简单,3-5分钟就能解决,结果竟然写了半小时,既然这样,就把这个给总结下。

思路

1、循环数据,放到hash中,把标识的数据作为key。

2、处理数据,循环数据,通过hash的查找拼接数据

3、go中的难点在于定义数据的格式

type BusinessRelationOther struct {
    TkBusinessRelation `xorm:"extends"`
    ClassName          string                  `json:"class_name" ` // class的name
    DateName           string                  `json:"date_name" `  // 第三方的name
    List               []BusinessRelationOther `json:"list"`
}

展示下代码

// buildData 数据的资源组装
func (myL *BusinessRelationLogic) buildData(list []models.BusinessRelationOther) map[int]map[int]models.BusinessRelationOther {
    var data map[int]map[int]models.BusinessRelationOther = make(map[int]map[int]models.BusinessRelationOther)
    for _, v := range list {
        id := v.Id
        fid := v.ParentId
        if _, ok := data[fid]; !ok {
            data[fid] = make(map[int]models.BusinessRelationOther)
        }
        data[fid][int(id)] = v
    }
    return data
}

// makeTreeCore 图形化
func (myL *BusinessRelationLogic) makeTreeCore(index int, data map[int]map[int]models.BusinessRelationOther) []models.BusinessRelationOther {
    tmp := make([]models.BusinessRelationOther, 0)
    for id, item := range data[index] {
        if data[id] != nil {
            item.List = myL.makeTreeCore(id, data)
        }
        tmp = append(tmp, item)
    }
    return tmp
}

data := myL.buildData(sBusinessRelationFac.BusinessRelationOtherSlicePtr)
result := myL.makeTreeCore(0, data)
 

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
英语口语笔记B1-Unit06.社交活动-01-Where should we go for dinner发布时间:2022-07-10
下一篇:
Go语言发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap