vue3+element-plus 实现动态菜单和动态路由的渲染

目录的数据结构,其中还包括二级目录

复制代码
import { useRoute, useRouter } from 'vue-router'
import MenuTree from './components/MenuTree.vue'

const route = useRoute()
const router = useRouter()
const subchildren = ref(目录数据)

<el-menu
        active-text-color="#88733C"
        background-color="#e3ddd0"
        :default-active="$route.path"
        text-color="#808080"
        router
      >
        <MenuTree :menuList="subchildren"></MenuTree>
</el-menu>

子组件MenuTree:

复制代码
<script setup>
const props = defineProps(['menuList'])
</script>
<template>
  <template v-for="item in props.menuList" :key="item.id">
    <!-- {{ item }} -->
    <!--      分为两种方式渲染:有子菜单和没有子菜单-->
    <el-sub-menu :index="item.name" v-if="item.children.length !== 0">
      <template #title>
        <span>{{ item.title }}</span>
      </template>
      <!--        有子菜单的继续遍历(递归)-->
      <MenuTree :menuList="item.children"></MenuTree>
    </el-sub-menu>
    <!--      没有子菜单-->
    <el-menu-item :index="item.name" v-else>
      <span>{{ item.title }}</span>
    </el-menu-item>
  </template>
</template>
<style lang="scss" scoped></style>
相关推荐
蓝黑20203 小时前
Vue导入和注册组件
前端·javascript·vue
ct9783 小时前
Vue3 状态管理方案:Pinia 全指南
javascript·vue.js
见青..3 小时前
DedeCMS织梦5.7--CSRF漏洞复现
前端·网络安全·csrf·漏洞复现
浩星3 小时前
electron系列3:进程模型深度解析:主进程、渲染进程、预加载脚本
前端·electron·前端框架
恋猫de小郭3 小时前
手机直接运行 Codex/OpenCode/Claude Code ,实时管理你的 AI Coding
前端·openai·ai编程
Canace3 小时前
为什么不要让LLM帮我们写文档
前端·人工智能
之歆3 小时前
前端性能优化:从路由懒加载到打包优化
前端·性能优化
米丘3 小时前
ESTree 规范 (acorn@8.15.0示例)
前端·javascript·编译器
天下权3 小时前
OpenLayers 地图绘制与交互实战:从零构建一个完整的绘制系统
前端·gis