第171天学习打卡(项目 谷粒商城13 菜单三级分类显示)

三级分类

image-20210628194347873

image-20210628195816466

 

image-20210628195923011

image-20210628200048380

image-20210628200143596

CategoryServiceImpl.java

查询所有分类

 package com.doudou.gulimall.product.service.impl;
 
 
 import org.springframework.stereotype.Service;
 
 import java.util.List;
 import java.util.Map;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.doudou.common.utils.PageUtils;
 import com.doudou.common.utils.Query;
 
 import com.doudou.gulimall.product.dao.CategoryDao;
 import com.doudou.gulimall.product.entity.CategoryEntity;
 import com.doudou.gulimall.product.service.CategoryService;
 
 
 @Service("categoryService")
 public class CategoryServiceImpl extends ServiceImpl<CategoryDao, CategoryEntity> implements CategoryService {
 //   @Autowired
 //   CategoryDao categoryDao;
 
     @Override
     public PageUtils queryPage(Map<String, Object> params) {
         IPage<CategoryEntity> page = this.page(
                 new Query<CategoryEntity>().getPage(params),
                 new QueryWrapper<CategoryEntity>()
        );
 
         return new PageUtils(page);
    }
 
     @Override
     public List<CategoryEntity> listWithTree() {
         // 1.查出所有分类
         List<CategoryEntity> entities = baseMapper.selectList(null);//这里写null(没有查询条件,就是查询所有)就是查询所有的数据
 
 
         //2.组装成父子的树形结构
         return entities;
 
 
 
 
    }
 
 }
 

image-20210628201434258

获取一级分类

CategoryServiceImpl .java

 package com.doudou.gulimall.product.service.impl;
 
 
 import org.springframework.stereotype.Service;
 
 import java.util.List;
 import java.util.Map;
 import java.util.stream.Collectors;
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.doudou.common.utils.PageUtils;
 import com.doudou.common.utils.Query;
 
 import com.doudou.gulimall.product.dao.CategoryDao;
 import com.doudou.gulimall.product.entity.CategoryEntity;
 import com.doudou.gulimall.product.service.CategoryService;
 
 
 @Service("categoryService")
 public class CategoryServiceImpl extends ServiceImpl<CategoryDao, CategoryEntity> implements CategoryService {
 //   @Autowired
 //   CategoryDao categoryDao;
 
     @Override
     public PageUtils queryPage(Map<String, Object> params) {
         IPage<CategoryEntity> page = this.page(
                 new Query<CategoryEntity>().getPage(params),
                 new QueryWrapper<CategoryEntity>()
        );
 
         return new PageUtils(page);
    }
 
     @Override
     public List<CategoryEntity> listWithTree() {
         // 1.查出所有分类
         List<CategoryEntity> entities = baseMapper.selectList(null);//这里写null(没有查询条件,就是查询所有)就是查询所有的数据
 
 
         //2.组装成父子的树形结构
 
         //2.1 找到所有的一级分类
         List<CategoryEntity> level1Menus = entities.stream().filter(categoryEntity ->
         categoryEntity.getParentCid() == 0
 
        ).collect(Collectors.toList());
 
 
         return level1Menus;
 
 
 
 
    }
 
 }
 

image-20210628202144159

查找子菜单

 

image-20210628202636210

CategoryServiceImpl.java

 package com.doudou.gulimall.product.service.impl;
 
 
 import org.springframework.stereotype.Service;
 
 import java.util.List;
 import java.util.Map;
 import java.util.stream.Collectors;
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.doudou.common.utils.PageUtils;
 import com.doudou.common.utils.Query;
 
 import com.doudou.gulimall.product.dao.CategoryDao;
 import com.doudou.gulimall.product.entity.CategoryEntity;
 import com.doudou.gulimall.product.service.CategoryService;
 
 
 @Service("categoryService")
 public class CategoryServiceImpl extends ServiceImpl<CategoryDao, CategoryEntity> implements CategoryService {
 //   @Autowired
 //   CategoryDao categoryDao;
 
     @Override
     public PageUtils queryPage(Map<String, Object> params) {
         IPage<CategoryEntity> page = this.page(
                 new Query<CategoryEntity>().getPage(params),
                 new QueryWrapper<CategoryEntity>()
        );
 
         return new PageUtils(page);
    }
 
     @Override
     public List<CategoryEntity> listWithTree() {
         // 1.查出所有分类
         List<CategoryEntity> entities = baseMapper.selectList(null);//这里写null(没有查询条件,就是查询所有)就是查询所有的数据
 
 
         //2.组装成父子的树形结构
 
         //2.1 找到所有的一级分类
         List<CategoryEntity> level1Menus = entities.stream().filter(categoryEntity ->
         categoryEntity.getParentCid() == 0
 
        ).map((menu)->{
             menu.setChildren(getChildrens(menu, entities));
             return menu;
        }).sorted((menu1, menu2)->{
             return (menu1.getSort() == null ? 0 : menu1.getSort()) - (menu2.getSort() == null ? 0 : menu2.getSort());
        }).collect(Collectors.toList());
 
 
         return level1Menus;
 
    }
     //递归查找所有菜单的子菜单
 
     private List<CategoryEntity> getChildrens(CategoryEntity root, List<CategoryEntity> all){
         List<CategoryEntity> childrean =all.stream().filter(categoryEntity -> {
             return categoryEntity.getParentCid() == root.getCatId();
        }).map(categoryEntity -> {
             //找到子菜单
             categoryEntity.setChildren(getChildrens(categoryEntity, all));
             return categoryEntity;
        }).sorted((menu1, menu2)->{
             //2.菜单排序
             return (menu1.getSort() == null ? 0 : menu1.getSort()) - (menu2.getSort() == null ? 0 : menu2.getSort());
        }).collect(Collectors.toList());
         return childrean;
 
    }
 
 }
 

image-20210628210253015

image-20210628210223548

 

配置网关路由和路径重写

先启动后台管理系统:

image-20210628211138293

然后启前端管理系统:

image-20210628212718969

image-20210628212701024

image-20210628212921965

image-20210628213401488

 

image-20210628213441966

B站学习网址:全网最强电商教程《谷粒商城》对标阿里P6/P7,40-60万年薪哔哩哔哩bilibili

 

posted @ 2021-06-28 21:41  豆豆tj  阅读(236)  评论(0)    收藏  举报