go中的无限极分类的问题

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

思路

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

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

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

type BusinessRelationOther struct {
    TkBusinessRelation `xorm:"extends"`
    ClassName          string                  `json:class_name" ` // class的name
    DateName           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]models.BusinessRelationOther = make(map[]models.BusinessRelationOther)
    for _,v := range list {
        id := v.Id
        fid := v.ParentId
        if _,ok := data[fid]; !ok {
            data[fid] = make(map[]models.BusinessRelationOther)
        }
        data[fid][int(id)] = v
    }
    return data
}

 makeTreeCore 图形化
func (myL *BusinessRelationLogic) makeTreeCore(index int,data map[]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)
    }
     tmp
}

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

 

相关文章

什么是Go的接口? 接口可以说是一种类型,可以粗略的理解为他...
1、Golang指针 在介绍Golang指针隐式间接引用前,先简单说下...
1、概述 1.1 Protocol buffers定义 Protocol buffe...
判断文件是否存在,需要用到"os"包中的两个函数: os.Stat(...
1、编译环境 OS :Loongnix-Server Linux release 8.3 CPU指...
1、概述 Golang是一种强类型语言,虽然在代码中经常看到i:=1...