2023-03-04 09:16:33 +08:00
|
|
|
<template>
|
|
|
|
|
<template v-for="subItem in menuList" :key="subItem.path">
|
|
|
|
|
<el-sub-menu v-if="subItem.children && subItem.children.length > 0" :index="subItem.path">
|
|
|
|
|
<template #title>
|
2023-03-24 19:36:11 +08:00
|
|
|
<!-- <img :src="require(`@/assets/images/leftTab/${subItem.meta.icon}`)" /> -->
|
|
|
|
|
<img :src="`${imgUrl + subItem.meta.icon}`" />
|
|
|
|
|
<!-- <img :src="`${subItem.meta.checkIcon}`" /> -->
|
|
|
|
|
<!-- <component :is="subItem.meta.icon"></component> -->
|
|
|
|
|
|
2023-03-04 09:16:33 +08:00
|
|
|
<span>{{ subItem.meta.title }}</span>
|
|
|
|
|
</template>
|
|
|
|
|
<SubMenu :menuList="subItem.children" />
|
|
|
|
|
</el-sub-menu>
|
|
|
|
|
<el-menu-item v-else :index="subItem.path" @click="handleClickMenu(subItem)">
|
2023-03-24 19:36:11 +08:00
|
|
|
<!-- <img :src="`${subItem.meta.icon}`" /> -->
|
|
|
|
|
<img :src="`${imgUrl + subItem.meta.icon}`" />
|
|
|
|
|
<!-- <img :src="`${subItem.meta.checkIcon}`" /> -->
|
2023-03-04 09:16:33 +08:00
|
|
|
<template #title>
|
|
|
|
|
<span>{{ subItem.meta.title }}</span>
|
|
|
|
|
</template>
|
|
|
|
|
</el-menu-item>
|
|
|
|
|
</template>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script setup lang="ts">
|
2023-03-24 19:36:11 +08:00
|
|
|
import { ref } from "vue";
|
2023-03-04 09:16:33 +08:00
|
|
|
import { useRouter } from "vue-router";
|
|
|
|
|
|
|
|
|
|
defineProps<{ menuList: Menu.MenuOptions[] }>();
|
|
|
|
|
|
|
|
|
|
const router = useRouter();
|
2023-03-24 19:36:11 +08:00
|
|
|
const imgUrl = "/src/assets/images/leftTab/";
|
2023-03-04 09:16:33 +08:00
|
|
|
const handleClickMenu = (subItem: Menu.MenuOptions) => {
|
|
|
|
|
if (subItem.meta.isLink) return window.open(subItem.meta.isLink, "_blank");
|
|
|
|
|
router.push(subItem.path);
|
|
|
|
|
};
|
|
|
|
|
</script>
|