当前位置: 首页 > news >正文

vue3学习——封装菜单栏

@/Layout/Sidebar/index.vue

<script setup lang="ts">
import Sidebar from './Sidebar.vue' // 在下面的代码里
import { useRoute } from 'vue-router'
import useUserStore from '@/store/modules/user.ts' // state中存放菜单数据
import useLayoutSetting from '@/store/modules/setting.ts' // state存放多页面公用大的数据(fold: 侧边菜单栏是否折叠)
const settingLayout = useLayoutSetting()
const userStore = useUserStore()
const route = useRoute()
</script><template><div class="sidebar_container"><el-scrollbar><el-menurouterunique-opened:default-active="route.path":collapse="settingLayout.fold"active-text-color="#fff"background-color="#001529"class="el-menu-vertical-demo"text-color="#959ea7"><Sidebarv-for="(item, i) in userStore.menuList":key="i":menu="item"/></el-menu></el-scrollbar></div>
</template><style lang="scss" scoped>
.sidebar_container {transition: all 0.5s;.el-scrollbar {height: calc(100vh - 60px);overflow-y: auto;.el-menu {border-right: none;}}
}
.fold {width: $sidebar-min-width;
}
</style>

@/Layout/Sidebar/Sidebar.vue

<script setup lang="ts">
defineProps(['menu'])
</script>
<script lang="ts">
export default {name: 'MenuItem',
}
</script>
<template><!-- 没有子路由 --><el-menu-item :index="menu.path" v-if="!menu.children && !menu.meta.hidden"><el-icon v-if="menu.meta"><component :is="menu.meta.icon"></component></el-icon><template #title><span>{{ menu.meta.title }}</span></template></el-menu-item><!-- 有子路由但只有一个 --home --><el-menu-item:index="menu.children[0].path"v-if="menu.children &&menu.children.length === 1 &&menu.path === '/' &&!menu.meta.hidden"><el-icon><component :is="menu.children[0].meta.icon"></component></el-icon><template #title><span>{{ menu.children[0].meta.title }}</span></template></el-menu-item><!-- 有子路由但只有一个 --not home --><el-sub-menu:index="menu.path"v-if="menu.children &&menu.children.length === 1 &&menu.path !== '/' &&!menu.meta.hidden"><el-icon v-if="menu.meta"><component :is="menu.meta.icon"></component></el-icon><template #title><span>{{ menu.meta.title }}</span></template><el-menu-item :index="menu.children[0].path"><template #title><el-icon v-if="menu.children[0].meta"><component :is="menu.children[0].meta.icon"></component></el-icon><span>{{ menu.children[0].meta.title }}</span></template></el-menu-item></el-sub-menu><!-- 有子路由且大于一个 --><el-sub-menu:index="menu.path"v-if="menu.children && menu.children.length > 1 && !menu.meta.hidden"><template #title><el-icon><component :is="menu.meta.icon"></component></el-icon><span>{{ menu.meta.title }}</span></template><MenuItem v-for="(item, i) in menu.children" :key="i" :menu="item" /></el-sub-menu>
</template><style lang="scss" scoped></style>
http://www.lryc.cn/news/298541.html

相关文章:

  • 深度学习的进展及其在各领域的应用
  • blender怎么保存窗口布局,怎么设置默认输出文件夹
  • 【开源】基于JAVA+Vue+SpringBoot的实验室耗材管理系统
  • 【ES】--Elasticsearch的分词器详解
  • 【算法】{画决策树 + dfs + 递归 + 回溯 + 剪枝} 解决排列、子集问题(C++)
  • sqlserver 存储过程
  • C语言什么是悬空指针?
  • AES加密后的密码可以破解吗
  • vue3学习——路由进度条
  • VMware虚拟机安装Windows系统教程
  • vue3学习——router-view 过渡动画
  • 从HSE攻击事件漫谈针对勒索攻击防御的两大误区
  • 设计模式(结构型模式)外观模式
  • C语言函数的栈帧与销毁(面试亮点)
  • 使用 GreenSock(GSAP)实现 字符串动画
  • linux系统zabbix监控服务端部署
  • 算法----回溯(附录---剪枝)
  • 从Unity到Three.js(模型文件加载)
  • Webshell一句话木马
  • 【Web】Spring rce CVE-2022-22965漏洞复现学习笔记
  • springboot/ssm大学生选修选课系统高校选课排课成绩管理系统Java系统
  • 【芯片设计- RTL 数字逻辑设计入门 14 -- 使用子模块实现三输入数的大小比较】
  • Xilinx FPGA——在线升级
  • 电商小程序02数据源设计
  • Leetcode 3033. Modify the Matrix
  • 蓝桥杯刷题--python-4
  • openJudge | 距离排序
  • 【算法】排序详解(快速排序,堆排序,归并排序,插入排序,希尔排序,选择排序,冒泡排序)
  • LeetCode Python -8.字符串转整数
  • 【java】笔记10:类与对象——本章练习