教你如何使用Java8實(shí)現(xiàn)菜單樹形數(shù)據(jù)
Java8實(shí)現(xiàn)菜單樹形數(shù)據(jù)
當(dāng)我們打開京東商城時(shí),左側(cè)的菜單依次分為三級(jí)展示,這是如何實(shí)現(xiàn)的呢?
本篇暫不講述前端,只講述如何使用java8 的lamada表達(dá)式實(shí)現(xiàn)樹形數(shù)據(jù)的拼裝
1.創(chuàng)建菜單表
CREATE TABLE `pms_category` ( `cat_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '分類id', `name` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '分類名稱', `parent_cid` bigint(20) NULL DEFAULT NULL COMMENT '父分類id', `cat_level` int(11) NULL DEFAULT NULL COMMENT '層級(jí)', `show_status` tinyint(4) NULL DEFAULT NULL COMMENT '是否顯示[0-不顯示,1顯示]', `sort` int(11) NULL DEFAULT NULL COMMENT '排序', `icon` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '圖標(biāo)地址', `product_unit` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '計(jì)量單位', `product_count` int(11) NULL DEFAULT NULL COMMENT '商品數(shù)量', PRIMARY KEY (`cat_id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 1433 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '商品三級(jí)分類' ROW_FORMAT = Dynamic;
2.創(chuàng)建實(shí)體類
其中children用來存放子類
@Data @TableName("pms_category") public class CategoryEntity implements Serializable { private static final long serialVersionUID = 1L; /** * 分類id */ @TableId private Long catId; /** * 分類名稱 */ private String name; /** * 父分類id */ private Long parentCid; /** * 層級(jí) */ private Integer catLevel; /** * 是否顯示[0-不顯示,1顯示] */ private Integer showStatus; /** * 排序 */ private Integer sort; /** * 圖標(biāo)地址 */ private String icon; /** * 計(jì)量單位 */ private String productUnit; /** * 商品數(shù)量 */ private Integer productCount; /** * 子分類 */ @TableField(exist = false) private List<CategoryEntity> children; }
3.實(shí)現(xiàn)一級(jí)分類
3.1)首先要查詢出所有的分類信息entities
3.2)然后對(duì)entities過濾查找一級(jí)分類,其中一級(jí)分的parentId == 0
3.3)設(shè)置當(dāng)前一級(jí)分類的子分類
3.4)對(duì)一級(jí)分類進(jìn)行排序
代碼如下:
public List<CategoryEntity> listWithTree() { //1.查詢所有分類 List<CategoryEntity> entities = baseMapper.selectList(null); //2.組裝 //2.1) 所到所有的一級(jí)類別 ,parentId = 0 List<CategoryEntity> levelOneMenus = entities.stream() .filter(item -> item.getParentCid() == 0) .map(item -> { item.setChildren(this.getChildrens(item, entities)); return item; }) .sorted((item1, item2) -> { return (item1.getSort() == null ? 0 : item1.getSort()) - (item2.getSort() == null ? 0 : item2.getSort()); }) .collect(Collectors.toList()); return levelOneMenus; }
4.使用遞歸對(duì)子分類再進(jìn)行樹形組裝
4.1)首先判斷當(dāng)前的id是否有等于集合中的元素的parentId
4.2)再對(duì)當(dāng)前子分類使用遞歸設(shè)置子分類
4.3)對(duì)當(dāng)前子分類排序
4.4)返回子分類集合
詳細(xì)代碼實(shí)現(xiàn)如下:
private List<CategoryEntity> getChildrens(CategoryEntity root, List<CategoryEntity> all){ List<CategoryEntity> treeMenus = all.stream() //如果菜單中的父菜單Id == 當(dāng)前菜單的id,則說明是子菜單 .filter(item -> Objects.equals(item.getParentCid(), root.getCatId())) .map(item -> { //遞歸添加子菜單 List<CategoryEntity> childrens = getChildrens(item, all); item.setChildren(childrens); return item; }) //排序 .sorted((item1, item2) -> { return (item1.getSort() == null ? 0 : item1.getSort()) - (item2.getSort() == null ? 0 : item2.getSort()); }) .collect(Collectors.toList()); return treeMenus; }
到此這篇關(guān)于教你如何使用Java8實(shí)現(xiàn)菜單樹形數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Java8實(shí)現(xiàn)菜單樹形數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IDEA手動(dòng)添加junit4時(shí)出現(xiàn)的問題與解決方法
這篇文章主要給大家介紹了關(guān)于IDEA手動(dòng)添加junit4時(shí)出現(xiàn)的問題與解決方法,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03Javaweb會(huì)話跟蹤技術(shù)Cookie和Session的具體使用
本文主要介紹了Javaweb會(huì)話跟蹤技術(shù)Cookie&Session的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07解決MyEclipse中Maven設(shè)置jdk版本jdk1.8報(bào)錯(cuò)問題
今天安裝了jdk1.8、tomcat8、和maven3.5.2,弄好后在myeclipse新建了一個(gè)maven項(xiàng)目,項(xiàng)目默認(rèn)是jdk1.5,改成jdk1.8后項(xiàng)目報(bào)錯(cuò)2018-10-10MySQL查詢字段實(shí)現(xiàn)字符串分割split功能的示例代碼
本文主要介紹了MySQL查詢字段實(shí)現(xiàn)字符串分割split功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01SpringBoot下載Excel文件時(shí),報(bào)錯(cuò)文件損壞的解決方案
這篇文章主要介紹了SpringBoot下載Excel文件時(shí),報(bào)錯(cuò)文件損壞的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06