vue3 vue-router 404 重定向 别名 嵌套路由 命名视图 元信息 (三)

文章目录

一、404 Not found 路由

当用户输入任何未知的路径时,Vue Router都将显示我们定义的404页面。这种方式使得我们能够更好地控制用户访问未知路径时的行为,提供更友好和统一的用户体验

javascript 复制代码
// 添加通配符路由
  { path: '/:catchAll(.*)', component: () => import("@/views/notFound/index.vue"), }

二、重定向

通过重定向,可以将一个路径重定向到另一个指定的路径

javascript 复制代码
 {
    path: "/home",
    name: "home",
    component: () => import("@/views/home/index.vue"),
  },
  {
    path: "/login",
    redirect: { path: "/home" },
  },

三、别名

可以使用别名来为路由配置添加额外的路径。这在某些情况下非常有用,比如需要将旧的路径重定向到新的路径,同时保留旧路径仍然可以访问

javascript 复制代码
{
    path: "/home",
    name: "home",
    alias: "/index",
    component: () => import("@/views/home/index.vue"),
  },

四、嵌套路由

可以使用Vue Router来配置嵌套路由,创建具有层次结构的路由布局

javascript 复制代码
{
    path: '/parent',
    component: ParentComponent,
    children: [
      {
        path: 'child',
        component: ChildComponent
      }
    ]
  }

当用户访问/parent时,ParentComponent会渲染,并且ChildComponent会出现在<router-view>中。

五、命名视图

同一个路由中同时渲染多个组件。这对于需要在同一页面上显示多个组件的情况非常有用

javascript 复制代码
<router-view name="sidebar"></router-view>
<router-view ></router-view>
javascript 复制代码
 {
    path: '/',
    components: {
      default: ComponentA,
      sidebar: ComponentB
    }
  }

在上面的示例中,我们为根路径/的路由配置中定义了两个组件:ComponentA 和 ComponentB,分别被命名为 default 和 sidebar。这意味着 ComponentA 将会被渲染到默认的 <router-view> 中,而 ComponentB 将会被渲染到名为 sidebar 的 <router-view> 中。

六、路由元信息

可以使用路由元信息(Route Meta Fields)来为路由添加自定义数据或标记。这些元信息可以帮助我们在导航守卫、组件钩子或其他地方访问到特定路由的相关信息

设置路由元信息

javascript 复制代码
{
    path: "/home",
    name: "home",
    alias: "/index",
    component: () => import("@/views/home/index.vue"),
    meta: { requiresAuth: true },
    children: [
      {
        path: "child",
        component: () => import("@/views/child/index.vue"),
      },
    ],
  },
  {
    path: "/about/:id",
    name: "about",
    meta: { requiresAuth: false },
    component: () => import("@/views/about/index.vue"),
  },

访问路由元信息

javascript 复制代码
// 在导航守卫中访问路由元信息
router.beforeEach((to, from, next) => {
  if (to.meta.requiresAuth) {
    // 需要身份验证的逻辑...
  } else {
    // 不需要身份验证的逻辑...
  }
})
javascript 复制代码
if (route.meta.requiresAuth) {
  // 需要身份验证的逻辑...
} else {
  // 不需要身份验证的逻辑...
}
相关推荐
苏打水com3 小时前
第九篇:Day25-27 Vue进阶——组件复用与状态管理(对标职场“复杂项目”需求)
前端·javascript·vue.js
老华带你飞3 小时前
博物馆展览门户|基于Java博物馆展览门户系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
PineappleCoder4 小时前
别让页面 “鬼畜跳”!Google 钦点的 3 个性能指标,治好了我 80% 的用户投诉
前端·性能优化
卤代烃4 小时前
🕹️ [AI] Chrome DevTools MCP 原理分析
前端·mcp
梦里不知身是客114 小时前
flink对于迟到数据的处理
前端·javascript·flink
卤代烃4 小时前
🤝 了解 CDP (Chrome DevTools Protocol):browser-use 背后的隐藏功臣
前端·chrome·puppeteer
一 乐4 小时前
人事管理系统|基于Springboot+vue的企业人力资源管理系统设计与实现(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·后端
b***74885 小时前
前端状态系统的时代变革:从本地状态到全局状态,再到智能状态的未来趋势
前端·状态模式
秋氘渔5 小时前
Vue 3 组合式API中的生命周期钩子函数介绍
前端·javascript·vue.js
拉不动的猪5 小时前
requestAnimationFrame 与 JS 事件循环:宏任务执行顺序分析
前端·javascript·面试