easymall----管理后端分类展示

目的效果

建表思路:categoryId是必须的 标识产品本身 因为是树形结构需要与父id联动 所以需要 pcategoryId 产品本身需要名字 所以需要 category_name

所以最基础的字段只需要这三个

表格展示:

sort字段为额外功能 可以通过前端拖动进行人为的排序 可加可不加

controller层:

复制代码
@RequestMapping("/loadCategory")
public ResponseVO loadCategory(){
    SysCategoryQuery sysCategoryQuery = new SysCategoryQuery();
    sysCategoryQuery.setOrderBy("s.sort asc");
    return getSuccessResponseVO(sysCategoryService.findListByParam(sysCategoryQuery));
}

实现层:

复制代码
@Override
public List<SysCategory> findListByParam(SysCategoryQuery param) {
    List<SysCategory> sysCategoryList = this.sysCategoryMapper.selectList(param);
 
    sysCategoryList = convertLine2Tree(sysCategoryList, Constants.ZERO_STR);
    
    return sysCategoryList;

}
private List<SysCategory> convertLine2Tree(List<SysCategory> dataList, String pid) {
    List<SysCategory> children = new ArrayList();
    for (SysCategory m : dataList) {
       if (m.getCategoryId() != null && m.getpCategoryId() != null && m.getpCategoryId().equals(pid)) {
          m.setChildren(convertLine2Tree(dataList, m.getCategoryId()));
          children.add(m);
       }
    }
    return children;
}

这部分需要细讲,要如图展示需要人为对类进行改造,要给sysCategory类加上List<sysCategory> children属性,便于树形展示 convertLine2Tree对查找到的所有数据进行递归 将子分类加入到children中

最后返回(小部分内容):

{

"status": "success",

"code": 200,

"info": "请求成功",

"data": [

{

"categoryId": "10001",

"categoryName": "数码家电",

"pCategoryId": "0",

"sort": 1,

"children": [

{

"categoryId": "20001",

"categoryName": "手机通讯",

"pCategoryId": "10001",

"sort": 1,

"children": []

},

{

"categoryId": "20002",

"categoryName": "电脑办公",

"pCategoryId": "10001",

"sort": 2,

"children": []

},

{

"categoryId": "20003",

"categoryName": "数码影音",

"pCategoryId": "10001",

"sort": 3,

"children": []

},

{

"categoryId": "20004",

"categoryName": "家用电器",

"pCategoryId": "10001",

"sort": 4,

"children": []

}

]

}

}

相关推荐
REDcker10 小时前
有限状态机与状态模式详解 FSM建模Java状态模式与C++表驱动模板实践
java·c++·状态模式
青春喂了后端13 小时前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式
不是山谷.:.16 小时前
前端性能优化全解析:从原理到落地,覆盖全领域与多技术栈
前端·笔记·性能优化·状态模式
星秀日19 小时前
Spring Boot + Sa-Token 实时聊天系统:用户注册流程源码深度剖析
java·人工智能·spring·状态模式
Maimai108081 天前
前端如何落地 SSE:从实时评论到可复用的实时数据 Hook
前端·javascript·react.js·前端框架·web3·状态模式·webassembly
前端不太难1 天前
从点击到意图:鸿蒙 App 的 AI 进化
人工智能·状态模式·harmonyos
多加点辣也没关系1 天前
设计模式-状态模式
设计模式·状态模式
未若君雅裁1 天前
SpringMVC 执行流程详解
java·spring boot·spring·状态模式
前端不太难2 天前
AI 不只是聊天框:鸿蒙 App 新入口
人工智能·状态模式·harmonyos
吴声子夜歌2 天前
状态机——状态模式实现订单状态流转
状态模式