vue3之动态路由

本文介绍如何在Vue3中实现动态路由,通过后端返回的数据结构动态生成路由配置,并解决了路由跳转后的白屏问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

后端返回的数据结构如下图

在这里插入图片描述

修改router的index.ts文件

menus为拿到的数据,在setRoutes方法中组装路由

在这里插入图片描述
方法代码自取
/**

  • 设置动态路由
  • @param menus 接口菜单数据
  • @param parentName 父级路由名称
  • @param parentPath 父级路由路径
    /
    const components = import.meta.glob("@/views/**/
    .vue");
    const layouts = import.meta.glob(“@/layout/**/*.vue”);
    const setRoutes = (menus: any, parentName?: any, parentPath?: any) => {
    menus.forEach((menu: any) => {
    const route: any = {};
    route.path = parentPath ? ${parentPath}/${menu.route} : /${menu.route};
    if (menu.path === “null”) {
    route.name = parentName;
    } else {
    if (menu.path.includes(“layout/”)) {
    router.addRoute({
    path: “/”,
    name: “layout-” + menu.route,
    component: () => import(“@/layout/index.vue”)
    });
    route.name = menu.route;
    route.component = components[../${menu.path.split("layout/")[1]}.vue];
    router.addRoute(“layout-” + route.name, route);
    } else {
    route.name = menu.route;
    if (menu.path == “layout”) {
    route.component = layouts[../${menu.path}/index.vue];
    router.addRoute(route);
    } else {
    route.component = components[../${menu.path}.vue];
    router.addRoute(parentName, route);
    }
    }
    }
    if (menu.sonMenus.length > 0) {
    // console.log(route.name, route.path);
    setRoutes(menu.sonMenus, route.name, route.path);
    }
    });
    };

这里要注意的是,设置component一定要用 import.meta.glob

到这里我们的动态路由已经拼好了,但是页面路由跳转之后白屏,官方文档给的是return to.fullPath,试了无效。所以我在动态路由设置好之后执行一下router.push(to.fullPath);就可以跳转页面啦

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值