Java實(shí)現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù)
一、業(yè)務(wù)分析
根據(jù)前端需求返回如下數(shù)據(jù)格式


二、后端設(shè)計(jì)數(shù)據(jù)類型VO
/**
* @author TTc
* @version 1.0
* @date 2024/2/15 16:47
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Catalog2Vo {
/**
* 一級父分類的 id
*/
private String catalog1Id;
/**
* 三級子分類
*/
private List<Category3Vo> catalog3List;
private String id;
private String name;
/**
* 三級分類 vo
* 這里是一個(gè)內(nèi)部類,記得要用public方便外部new出這個(gè)對象
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public static class Category3Vo {
/**
* 父分類、二級分類 id
*/
private String catalog2Id;
private String id;
private String name;
}
}三、代碼實(shí)現(xiàn)
1.編寫Controller
//返回 json 數(shù)據(jù)
@GetMapping(value = "/index/catalog.json")
@ResponseBody
public Map<String, List<Catalog2Vo>> getCatalogJson() {
Map<String, List<Catalog2Vo>> catalogJson =
categoryService.getCatalogJson();
return catalogJson;
}
2.編寫Service
Map<String, List<Catalog2Vo>> getCatalogJson();
@Override
public Map<String, List<Catalog2Vo>> getCatalogJson() {
// 查詢所有的分類
List<CategoryEntity> selectList = this.baseMapper.selectList(null);
// 所有1級分類信息
List<CategoryEntity> level1Categorys = getLevel1Categorys();
// 循環(huán)所有的1級分類,設(shè)置每個(gè)1級分類下面的二級分類和三級分類信息
Map<String,List<Catalog2Vo>>jsonMap=
level1Categorys.stream().
collect(Collectors.toMap(k -> k.getId().toString(), v -> {
// 初始化二級分類信息
// 查詢當(dāng)前1級分類下的2級分類
// 當(dāng)前一級分類下的所有二級分類
List<CategoryEntity> categories2Level =
getCategoriesByParentId(selectList, v.getId());
List<Catalog2Vo> catalog2Vos =
categories2Level.stream().map(category2Level -> {
// 設(shè)置1級分類id
Catalog2Vo catalog2Vo = new Catalog2Vo(v.getId().toString(), null,
category2Level.getId().toString(), category2Level.getName());
// catalog2Vos.add(catalog2Vo);
// 當(dāng)前二級分類下的所有三級分類
List<CategoryEntity> categories3Level =
getCategoriesByParentId(selectList, category2Level.getId());
// 查詢當(dāng)前2級分類下的3級分類
List<Catalog2Vo.Category3Vo>category3VoList=
categories3Level.stream().map(category3Level -> {
// 初始化當(dāng)前二級分類下的三級分類信息
Catalog2Vo.Category3Vocategory3Vo=
new Catalog2Vo.Category3Vo(category2Level.getId().toString(),
category3Level.getId().toString(), category3Level.getName());
return category3Vo;
}).collect(Collectors.toList());
// 設(shè)置當(dāng)前二級分類下的所有三級分類集合
catalog2Vo.setCatalog3List(category3VoList);
return catalog2Vo;
}).collect(Collectors.toList());
return catalog2Vos;
}));
return jsonMap;
}3、結(jié)果展示


到此這篇關(guān)于Java實(shí)現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Java返回樹形3級層級數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis 獲取無數(shù)據(jù)的字段不顯示的問題
這篇文章主要介紹了mybatis 獲取無數(shù)據(jù)的字段不顯示的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
netty對proxy protocol代理協(xié)議的支持詳解
這篇文章主要為大家介紹了netty對proxy protoco代理協(xié)議的支持詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
Mybatis詳解動態(tài)SQL以及單表多表查詢的應(yīng)用
MyBatis的動態(tài)SQL是基于OGNL表達(dá)式的,它可以幫助我們方便的在SQL語句中實(shí)現(xiàn)某些邏輯,下面這篇文章主要給大家介紹了關(guān)于Mybatis超級強(qiáng)大的動態(tài)SQL語句的相關(guān)資料,需要的朋友可以參考下2022-06-06
網(wǎng)易Java程序員兩輪面試 請問你能答對幾個(gè)?
為大家分享網(wǎng)易Java程序員兩輪面試題,考考大家,這些問題你能答對幾個(gè)?2017-11-11
Java正則表達(dá)式Pattern和Matcher原理詳解
這篇文章主要介紹了Java正則表達(dá)式Pattern和Matcher原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02
Java 中一個(gè)類提供一個(gè)默認(rèn)對象的多種方法
這篇文章主要介紹了Java 中一個(gè)類提供一個(gè)默認(rèn)對象的多種方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07
SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源)
本文主要介紹了SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05

