Java實(shí)現(xiàn)根據(jù)前端所要格式返回樹形3級(jí)層級(jí)數(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 { /** * 一級(jí)父分類的 id */ private String catalog1Id; /** * 三級(jí)子分類 */ private List<Category3Vo> catalog3List; private String id; private String name; /** * 三級(jí)分類 vo * 這里是一個(gè)內(nèi)部類,記得要用public方便外部new出這個(gè)對(duì)象 */ @Data @AllArgsConstructor @NoArgsConstructor public static class Category3Vo { /** * 父分類、二級(jí)分類 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級(jí)分類信息 List<CategoryEntity> level1Categorys = getLevel1Categorys(); // 循環(huán)所有的1級(jí)分類,設(shè)置每個(gè)1級(jí)分類下面的二級(jí)分類和三級(jí)分類信息 Map<String,List<Catalog2Vo>>jsonMap= level1Categorys.stream(). collect(Collectors.toMap(k -> k.getId().toString(), v -> { // 初始化二級(jí)分類信息 // 查詢當(dāng)前1級(jí)分類下的2級(jí)分類 // 當(dāng)前一級(jí)分類下的所有二級(jí)分類 List<CategoryEntity> categories2Level = getCategoriesByParentId(selectList, v.getId()); List<Catalog2Vo> catalog2Vos = categories2Level.stream().map(category2Level -> { // 設(shè)置1級(jí)分類id Catalog2Vo catalog2Vo = new Catalog2Vo(v.getId().toString(), null, category2Level.getId().toString(), category2Level.getName()); // catalog2Vos.add(catalog2Vo); // 當(dāng)前二級(jí)分類下的所有三級(jí)分類 List<CategoryEntity> categories3Level = getCategoriesByParentId(selectList, category2Level.getId()); // 查詢當(dāng)前2級(jí)分類下的3級(jí)分類 List<Catalog2Vo.Category3Vo>category3VoList= categories3Level.stream().map(category3Level -> { // 初始化當(dāng)前二級(jí)分類下的三級(jí)分類信息 Catalog2Vo.Category3Vocategory3Vo= new Catalog2Vo.Category3Vo(category2Level.getId().toString(), category3Level.getId().toString(), category3Level.getName()); return category3Vo; }).collect(Collectors.toList()); // 設(shè)置當(dāng)前二級(jí)分類下的所有三級(jí)分類集合 catalog2Vo.setCatalog3List(category3VoList); return catalog2Vo; }).collect(Collectors.toList()); return catalog2Vos; })); return jsonMap; }
3、結(jié)果展示
到此這篇關(guān)于Java實(shí)現(xiàn)根據(jù)前端所要格式返回樹形3級(jí)層級(jí)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Java返回樹形3級(jí)層級(jí)數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis 獲取無數(shù)據(jù)的字段不顯示的問題
這篇文章主要介紹了mybatis 獲取無數(shù)據(jù)的字段不顯示的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07netty對(duì)proxy protocol代理協(xié)議的支持詳解
這篇文章主要為大家介紹了netty對(duì)proxy protoco代理協(xié)議的支持詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Mybatis詳解動(dòng)態(tài)SQL以及單表多表查詢的應(yīng)用
MyBatis的動(dòng)態(tài)SQL是基于OGNL表達(dá)式的,它可以幫助我們方便的在SQL語(yǔ)句中實(shí)現(xiàn)某些邏輯,下面這篇文章主要給大家介紹了關(guān)于Mybatis超級(jí)強(qiáng)大的動(dòng)態(tài)SQL語(yǔ)句的相關(guān)資料,需要的朋友可以參考下2022-06-06網(wǎng)易Java程序員兩輪面試 請(qǐng)問你能答對(duì)幾個(gè)?
為大家分享網(wǎng)易Java程序員兩輪面試題,考考大家,這些問題你能答對(duì)幾個(gè)?2017-11-11Java正則表達(dá)式Pattern和Matcher原理詳解
這篇文章主要介紹了Java正則表達(dá)式Pattern和Matcher原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02Java 中一個(gè)類提供一個(gè)默認(rèn)對(duì)象的多種方法
這篇文章主要介紹了Java 中一個(gè)類提供一個(gè)默認(rèn)對(duì)象的多種方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源)
本文主要介紹了SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05