目标:
根据传入的参数:分类ID,获取商品的分类面包屑路径和最顶层分类的ID;
方法:
public HashMap<String,String> getCategoryAncestor(Long cateId) {
StringBuilder sb = new StringBuilder();
StringBuilder ct = new StringBuilder();
QueryWrapper<MarketCateDto> wrapper = new QueryWrapper<>();
wrapper.eq("market_cate_id", cateId);
MarketCateDto marketCateDto = ddMarketCateMapper.selectOne(wrapper);
HashMap<String, String> resultMap = new HashMap<>();
if (marketCateDto != null) {
String cateName = marketCateDto.getCateName();
Long firstLevelParentId = marketCateDto.getParentId(); // 这个应该是最顶层的父分类ID
Long marketCateId=marketCateDto.getMarketCateId();
// 获取父分类的祖先信息
HashMap<String, String> parentAncestors = getCategoryAncestor(firstLevelParentId);
if (parentAncestors != null) {
// 构建面包屑路径
sb.append(parentAncestors.get("breadCrumb")); // 先添加父分类的路径
sb.append(" > ").append(cateName); // 再添加当前分类的名称
ct.append(parentAncestors.get("marketCate"));
} else {
// 如果父分类没有祖先信息,直接添加当前分类的名称作为面包屑路径
sb.append(cateName);
ct.append(firstLevelParentId);
}
// 将分类名称和面包屑路径存入HashMap中
resultMap.put("firstLevel", ct.toString());
resultMap.put("marketCate", String.valueOf(firstLevelParentId));
resultMap.put("cateName", cateName);
resultMap.put("breadCrumb", sb.toString());
return resultMap;
}else {
return null;
}
}
欢迎小伙伴共同进步。