Java實現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù)
更新時間:2024年02月19日 10:40:42 作者:TTc_
這篇文章主要為大家詳細介紹了Java如何實現(xiàn)根據(jù)前端所要格式返回樹形3級層級數(shù)據(jù),文中的示例代碼講解詳細,有需要的小伙伴可以了解下
一、業(yè)務(wù)分析
根據(jù)前端需求返回如下數(shù)據(jù)格式
二、后端設(shè)計數(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 * 這里是一個內(nèi)部類,記得要用public方便外部new出這個對象 */ @Data @AllArgsConstructor @NoArgsConstructor public static class Category3Vo { /** * 父分類、二級分類 id */ private String catalog2Id; private String id; private String name; } }
三、代碼實現(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è)置每個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實現(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ù)的字段不顯示的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07netty對proxy protocol代理協(xié)議的支持詳解
這篇文章主要為大家介紹了netty對proxy protoco代理協(xié)議的支持詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07Mybatis詳解動態(tài)SQL以及單表多表查詢的應(yīng)用
MyBatis的動態(tài)SQL是基于OGNL表達式的,它可以幫助我們方便的在SQL語句中實現(xiàn)某些邏輯,下面這篇文章主要給大家介紹了關(guān)于Mybatis超級強大的動態(tài)SQL語句的相關(guān)資料,需要的朋友可以參考下2022-06-06SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源)
本文主要介紹了SpringBoot-JWT生成Token和攔截器的使用(訪問受限資源),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05