vue框架 element导航菜单el-submenu 简单使用方法--以侧边栏举例

1、目标

实现动态增删菜单栏的效果,所以要在数据库中建表

2 、建表

2.1、表样式

2.2、表数据

3、实体类

java 复制代码
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.List;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class PcMenu {
    private Integer id;
    private String name;//菜单名称
    private Integer parentId;//父级
    private String link;//前端链接
    private Integer status;//1:正常 0:禁用
    private String icon;//图标
    private List<PcMenu> childrenMenu;//子菜单
}

4、sql语句

xml 复制代码
 <select id="queryUserMenu" resultType="com.woniu.pc.entity.PcMenu">
    SELECT id, name, link, parentid, icon
    FROM t_pc_menu
</select>

5 、前端

xml 复制代码
<template>
  <el-container style="height: 100%" bcak>
    <el-header height="100px" style="background-color: cadetblue"> Header </el-header>
    <el-container>
      <el-aside width="200px" style="background-color: rgb(84, 92, 100)">
        <el-menu
          router
          class="el-menu-vertical-demo"
          background-color="#545c64"
          text-color="#fff"
          active-text-color="#ffd04b">
          <!-- 一级菜单循环体是el-submenu 二级菜单循环体是el-menu-item -->
          <!-- index  key 必须要转成字符串,不然控制台会报错-->
          <el-submenu :index="menu.id+''" v-for="menu in menuList" :key="menu.id">
            <template slot="title">
              <i :class="menu.icon"></i>
              <span>{{ menu.name }}</span>
            </template>
            <el-menu-item :index="c.link" v-for="c in menu.childrenMenu" :key="c.id+''">
              {{ c.name }}
            </el-menu-item>
          </el-submenu>
        </el-menu>
      </el-aside>
      <el-main style="background-color: rgb(255, 255, 255)">
        <router-view></router-view>
      </el-main>
    </el-container>
  </el-container>
</template>

<script>
  export default {
    data() {
      return {
        menuList: [],
      };
    },
    methods: {
      //查询用户拥有的菜单
      queryUserMenu() {
        this.$axios.get("api/employee/queryUserMenu").then((res) => {
          console.log(res.data);
          if (res.data.code == 200) {
            this.menuList = res.data.data;
          }
        });
      },
    },
    created() {
      this.queryUserMenu();
    },
  };
</script>

<style scope></style>
相关推荐
2501_920931701 天前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得01 天前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5161 天前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino1 天前
图片、文件的预览
前端·javascript
2501_920931701 天前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05281 天前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔1 天前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李1 天前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN1 天前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒1 天前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局