首页 > 教程
Ant Design Vue 4.0 侧边导航栏Menu组件封装
- 2025-04-07
- 1037 ℃
Ant Design Vue 4.0 a-modal 弹窗组件封装
<template>
<a-layout-sider>
<div>Han</div>
<a-menu v-model:selectedKeys="routerPathKey" theme="light" mode="inline" @click="onTitleClick" :openKeys="ACTIVE_NAV">
<template v-for="itm in NAV_MENU" :key="itm.name">
<a-sub-menu v-if="itm.children && itm.children.length" :key="itm.name">
<template #title>
<icon-font :type="(itm.meta?.icon as any)" />
<span>{{ itm.name }}</span>
</template>
<a-menu-item v-for="_itm in itm.children" :key="_itm.name">
<icon-font :type="(_itm.meta?.icon as any)" />
<span>{{ _itm.name }}</span>
</a-menu-item>
</a-sub-menu>
<a-menu-item v-if="!itm.children || itm.children.length < 1" :key="itm.name">
<icon-font :type="(itm.meta?.icon as any)" />
<span>{{ itm.name }}</span>
</a-menu-item>
</template>
<a-menu-item key="敬请期待" disabled>
<icon-font type="han-icon-jingqingqidai1" />
<span>敬请期待</span>
</a-menu-item>
</a-menu>
</a-layout-sider>
</template>
<script setup>
import { ref } from "vue";
import { useRouter } from "vue-router";
const router = useRouter();
// 阿里图标库
import { createFromIconfontCN } from "@ant-design/icons-vue";
const IconFont = createFromIconfontCN({
scriptUrl: "/icon/nav-icon/iconfont.js"
});
// 路由表
const NAV_MENU = router.options.routes[0].children;
// 路由跳转
const onTitleClick = (res: any) => {
router.push({ name: res.key });
};
// 路由监控
const routerPathKey = ref<Array<any>>([]);
// 刷新页面展开一级菜单
const ACTIVE_NAV = ref<string[]>([]);
const initFN = () => {
ACTIVE_NAV.value = [];
routerPathKey.value = [router.currentRoute.value.name];
NAV_MENU?.forEach((itm: any) => {
itm.children?.find((item: { name: string }) => {
return item.name == routerPathKey.value[0] && ACTIVE_NAV.value.push(itm.name);
});
});
};
initFN();
router.afterEach((to, from) => {
initFN();
});
</script>
<style scoped>
@import "index.less";
</style>相关内容
产品差异化竞争的 5 个建议
微信消费者保护安全锁,...
微信拍照模糊调用手机相...
JQUERY判断一个元素是否...
Ant Design Vue 4.0 ...
显示器比例影响效率?16:...
PHP判断URL的合法性字符...
最安全的PHP密码加密方法
-
如何搜索到自己想要的资源
2025-03-10 1410
-
批量重命名文件,怎样快速去除括号?去掉空格!
2021-10-29 1850
-
重症急性胰腺炎诊治指南
2024-06-18 1186
-
庞氏骗局是什么意思?数字货币是不是庞氏骗局
2024-05-10 1504
-
PTgui拼接全景照片方法
2021-07-08 798
-
Vue底层判断标签的性能优化方法
2025-04-07 1493
-
写代码时容易用到的基础函数总结
2025-04-07 967
-
可免费使用的网站CDN加速服务
2025-04-07 1176
-
Coze 扣子 - 字节出品的超强 AI Bot 工具教程,免费无限白嫖 GPT4 方法
2024-04-07 2868
-
微信的尊老爱幼模式,关怀模式和青少年模式
2025-06-22 1103
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


进入有缘空间
点击分享文章