Vue3-40-路由- 动态路由

说明

本文主要介绍了 对路由的动态配置,主要包括以下几个部分:
	1、判断某个路由是否存在;
	2、查看路由对象中的所有路由配置;
	3、添加一个路由;
	4、删除一个路由。

针对上述四个方面,vue-router 中提供了对应的 API ,
因此,本文将主要介绍对应的API及其使用方法。

API 说明

注意 : 以下API 都是 全局路由配置对象的方法!
hasRoute(路由名称) : 判断某个路由是否存在,参数为 目标路由的名称,即 name 属性;
getRoutes(): 无参数,返回路由列表;
addRoute(): 添加路由
removeRoute(路由名称): 移除路由,参数为 目标路由的名称,即 name属性

下面介绍一下具体的使用

判断路由是否存在 hasRoute

  // 引入路由相关的方法
  import {
    useRouter} from 'vue-router';

  // 声明 路由实例对象 
  const routerObj = useRouter()

  // 判断是否存在某个路由 : 参数是路由的 name 
  console.log('判断是否包含 /a 路由 :',routerObj.hasRoute('aroute'))

获取路由的配置列表 getRoutes

 // 引入路由相关的方法
  import {
    useRouter} from 'vue-router';

  // 声明 路由实例对象 
  const routerObj = useRouter()

  // 查看所有的路由对象
  console.log('所有的路由配置列表 :',routerObj.getRoutes())

添加路由

常规添加

参数只有一个,就是目标路由配置对象

  // 引入路由相关的方法
  import {
    useRouter} from 'vue-router';

  // 声明 路由实例对象 
  const routerObj = useRouter()

  // 执行路由对象的添加
  routerObj.addRoute({
   
            path:'/c',
            name:'croute',
            component: () => import('./componentC.vue')
        })

添加路由到某个路由下成为子路由

参数有两个:
参数1 : 父级路由的 name
参数2 :目标路由的配置对象

  // 引入路由相关的方法
  import {
    useRouter} from 'vue-router';

  // 声明 路由实例对象 
  const routerObj = useRouter()

  // 添加嵌套路由
  routerObj.addRoute('aroute',{
   
            path:'c',
            name:'crouteChild',
            component: () => import('./componentC.vue')
        })

移除路由

根据路由名称执行移除

  // 引入路由相关的方法
  import {
    useRouter} from 'vue-router';

  // 声明 路由实例对象 
  const routerObj = useRouter()

  // 根据名称移除路由
  routerObj.removeRoute('aroute')

当路由没有name的时候该怎么办

通常情况下,我们在路由配置的时候都会指定 【name】属性,
但是,在动态路由添加的时候,可能不会指定 【name】属性,
此时,就有了第二种的移除路由的方式,
那就是,在动态添加路由 addRoute() 的时候,会有一个返回值对象,
我们可以把这个返回值对象作为一个参数,调用一下,就会完成路由的移除动作。

代码如下:
  // 引入路由相关的方法
  import {
    useRouter} from 'vue-router';

  // 声明 路由实例对象 
  const routerObj = useRouter()

  // 接收一下 addRoute() 的回掉函数
  let routeCObj = routerObj.addRoute({
   
            path:'/c',
            name:'croute',
            component: () => import('./componentC.vue')
        })

  // 调用一下上面的回掉函数,对应的路由对象就被移除了
  routeCObj();
  // ok,完成移除操作

相关推荐

  1. Vue3-40-- 动态

    2024-01-10 22:16:04       29 阅读
  2. vue3如何实现动态

    2024-01-10 22:16:04       43 阅读
  3. vue3动态

    2024-01-10 22:16:04       18 阅读
  4. vue3

    2024-01-10 22:16:04       46 阅读
  5. Vue 实现动态

    2024-01-10 22:16:04       28 阅读
  6. Vue2 动态

    2024-01-10 22:16:04       11 阅读
  7. vue混入、动态匹配

    2024-01-10 22:16:04       41 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-10 22:16:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-10 22:16:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-10 22:16:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-10 22:16:04       18 阅读

热门阅读

  1. 2024年1月11日 晨会汇报

    2024-01-10 22:16:04       33 阅读
  2. mysql常见问题

    2024-01-10 22:16:04       33 阅读
  3. 向爬虫而生---Redis 拓宽篇3 <GEO模块>

    2024-01-10 22:16:04       32 阅读
  4. Qt基础-QtGlobal常用的全局函数及随机数产生实例

    2024-01-10 22:16:04       35 阅读
  5. 学习记录685@获取第三方文件后转存入自己服务器

    2024-01-10 22:16:04       36 阅读
  6. vue3利用自定义事件和v-model实现父子传参

    2024-01-10 22:16:04       37 阅读
  7. PAT (Basic Level)|1004成绩排名 c++满分题解

    2024-01-10 22:16:04       32 阅读
  8. flask flask-sqlalchemy sqlit3

    2024-01-10 22:16:04       32 阅读
  9. Linux kernel 学习笔记

    2024-01-10 22:16:04       46 阅读