网络编程
位置:首页>> 网络编程>> JavaScript>> vue3动态添加路由

vue3动态添加路由

作者:小绵杨Yancy  发布时间:2024-05-13 09:08:34 

标签:vue3,动态,添加,路由

前言

有的时候我们需要根据不同的用户身份生成不同的路由规则,例如:

vip用户应该有自己的vip页面所对应的专用路由。

一、初始化项目

初始化vite + vue + ts项目,引入vue-router。
目录结构如下,注意这个404重定向,vue3不支持直接使用“*”匹配所有路由了,要使用:catchAll(.*)

vue3动态添加路由

初始化路由:

import {createRouter, createWebHashHistory} from "vue-router";
const  routes = [
   {
       path: "/",
       component: () => import("../views/HomePage.vue")
   },
   {
       path: "/404",
       component: () => import("../views/ErrorPage.vue")
   },
   {
       path: "/:catchAll(.*)", // 不识别的path自动匹配404
       redirect: '/404',
   },
]
const router=createRouter({
   history: createWebHashHistory(),
   routes
})
export default router;

现在如果去访问vip路由,则会跳转到404页面。

vue3动态添加路由

二、添加“vip”路由

如果需要访问vip页面,那么就需要我们动态地添加vip路由,下面代码实现了vip路由添加:

import {useRouter} from "vue-router";
let router = useRouter();
function addRouter(){
 router.addRoute(  {
   path: "/vip",
   component: () => import("../views/VipPage.vue")
 })
}

此时我们再去访问vip路由路径:

vue3动态添加路由

可以成功访问了。

三、总结

可以了解到,动态添加路由就是使用了router对象的addRoute方法。有时候可能是添加嵌套路由,也就是子路由。

router.addRoute({ name: 'admin', path: '/admin', component: Admin })
router.addRoute('admin', { path: 'settings', component: AdminSettings })

// 这等效于:
router.addRoute({
 name: 'admin',
 path: '/admin',
 component: Admin,
 children: [{ path: 'settings', component: AdminSettings }],
})

来源:https://blog.csdn.net/ZHANGYANG_1109/article/details/125334900

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com