Files
Snap.Server.Web/src/components/SidebarItem.vue
2025-12-21 17:10:02 +08:00

56 lines
1.4 KiB
Vue

<template>
<template v-for="item in routes" :key="item.path">
<!-- 有子路由 -->
<el-sub-menu
v-if="hasChildren(item)"
:index="item.path"
>
<template #title>
<el-icon v-if="item.meta?.icon">
<component :is="icons[item.meta.icon as keyof typeof icons]" />
</el-icon>
<span>{{ item.meta?.title }}</span>
</template>
<SidebarItem :routes="item.children!" :parent-path="item.path" />
</el-sub-menu>
<!-- 普通菜单 -->
<el-menu-item
v-else
:index="getFullPath(item)"
>
<el-icon v-if="item.meta?.icon">
<component :is="icons[item.meta.icon as keyof typeof icons]" />
</el-icon>
<span>{{ item.meta?.title }}</span>
</el-menu-item>
</template>
</template>
<script setup lang="ts">
import type { RouteRecordRaw } from 'vue-router'
import * as icons from '@element-plus/icons-vue'
interface Props {
routes: RouteRecordRaw[]
parentPath?: string
}
const props = withDefaults(defineProps<Props>(), {
parentPath: ''
})
const hasChildren = (route: RouteRecordRaw) =>
route.children && route.children.length > 0
const getFullPath = (route: RouteRecordRaw) => {
// 如果是绝对路径,直接返回
if (route.path.startsWith('/')) {
return route.path
}
// 否则拼接父级路径
return props.parentPath ? `/${props.parentPath}/${route.path}` : `/${route.path}`
}
</script>