学习笔记:Vue Router 中的嵌套路由详解[特殊字符]概述

🧩 概述

在构建复杂单页应用(SPA)时,页面结构往往呈现多层次嵌套 。Vue Router 提供了 嵌套路由(Nested Routes) 功能,允许我们通过 URL 的层级关系映射到组件的嵌套结构。

例如:

🔁 嵌套路由基本原理

1. <router-view> 的作用机制

  • <router-view> 是一个动态插槽,用于渲染匹配的路由组件。

  • 顶层 App.vue 中的 <router-view> 渲染顶级路由组件(如 User)。

  • 若 User 组件中也包含 <router-view>,则可渲染其子组件(如 Profile 或 Posts)。

2. 路由配置中的 children 字段

使用 children 数组定义嵌套路由:

javascript 复制代码
const routes = [
  {
    path: '/user/:id',
    component: User,
    children: [
      { 
        path: 'profile',           // 实际路径: /user/:id/profile
        component: UserProfile 
      },
      { 
        path: 'posts',             // 实际路径: /user/:id/posts
        component: UserPosts 
      }
    ]
  }
]

✅ 注意:子路径不以 / 开头 ,否则被视为根路径;若以 / 开头,则脱离父级前缀。

3. 默认子路由(空路径)

当访问 /user/123 时,默认不显示任何子组件。可通过设置空路径 ' ' 显示默认内容:

javascript 复制代码
{
  path: '/user/:id',
  component: User,
  children: [
    { path: '', component: UserHome }, // 默认子路由
    { path: 'profile', component: UserProfile }
  ]
}

此时:

  • /user/123 → 显示 UserHome

  • /user/123/profile → 显示 UserProfile

🏷️ 命名嵌套路由

可以为嵌套路由命名,便于编程式导航或避免硬编码路径。

示例:命名子路由

javascript 复制代码
{
  path: '/user/:id',
  component: User,
  children: [
    { path: '', name: 'user', component: UserHome },
    { path: 'profile', name: 'user-profile', component: UserProfile }
  ]
}

跳转方式:

javascript 复制代码
// 使用名称跳转(需传参)
router.push({ name: 'user', params: { id: '123' } })

区别:

  • 访问 /user/123 → 触发 user-parent 路由,但最终仍进入 user 子路由(因为空子路径存在)

  • 刷新页面会恢复到子路由状态,因为浏览器按实际 URL 匹配路径

❗ 所以命名父路由主要用于编程导航,刷新后仍会进入子路由。

🚫 忽略父组件(Vue Router 4.1+)

从 Vue Router 4.1 起,支持"仅分组、无组件"的父路由------即父级不指定 component。

场景说明

将具有相同前缀的路由归类管理,比如后台管理系统 /admin/*:

javascript 复制代码
const routes = [
  {
    path: '/admin',
    children: [
      { path: '', component: AdminOverview },
      { path: 'users', component: AdminUserList },
      { path: 'users/:id', component: AdminUserDetails }
    ]
  }
]

此时:

  • /admin → 直接渲染 AdminOverview

  • /admin/users → 渲染 AdminUserList

  • 不需要创建一个空壳 Admin.vue 组件!

✅ 优势:简化结构,提升可维护性。

🎯 实际应用场景总结

应用场景 配置方式 是否需要嵌套视图
用户中心(个人资料、文章等) 使用 children + <router-view> ✅ 是
后台管理模块(admin/*) 可省略父组件,直接分组 ❌ 否
默认首页展示 设置空路径 { path: '' } ✅ 是
编程式导航跳转 使用 name 命名路由 可选

💡 关键知识点详解

知识点一:嵌套路由配置与 <router-view> 的对应关系

每个 <router-view> 对应一层 children 配置,形成树状结构,实现 UI 与 URL 的同步更新。

知识点二:命名路由在嵌套中的优先级与行为

命名路由可用于跳转,但页面刷新时始终依据 URL 匹配最深的有效路由,可能导致与预期不符。

知识点三:无组件父路由的路由分组功能

利用父子关系进行逻辑分组,无需创建中间组件,适用于权限控制、布局隔离等高级场景。

✅ 总结建议

  1. 合理使用嵌套:深度不宜超过 3 层,保持清晰易维护。

  2. 善用默认子路由 :避免空白 <router-view>。

  3. 命名路由增强可读性:尤其适合大型项目。

  4. 灵活选择是否使用父组件:根据业务需求决定是否省略父级组件。

  5. **结合 route.params 传递数据** :子组件可通过 route.params.id 获取动态参数。

📘 延伸学习推荐

提示:嵌套路由是构建企业级前端应用的核心技能之一,掌握它意味着你能更好地组织复杂界面与状态流。

相关推荐
小羊Yveesss11 小时前
2026年前端开发新趋势:智能协同、工具革新与场景深耕
前端·ai
Dxy123931021611 小时前
HTML中的Canvas可以干哪些事情
前端·html
悟乙己11 小时前
解析 Agent 时代的 HTML PPT SKILLS: html-ppt-skill
前端·html·powerpoint
ZC跨境爬虫11 小时前
跟着 MDN 学 HTML day_2:(表单分组与高级输入控件实战)
前端·javascript·css·ui·html
吴声子夜歌12 小时前
Vue3——UI组件库Element Plus(一)
vue.js·ui·elementplus
ppandss112 小时前
JavaWeb从0到1-DAY4-AJAX
前端·ajax·okhttp
千寻girling12 小时前
滑动窗口刷了快一个月(26天)了 , 还没有刷完. | 含(操作系统学什么的Java 后端)
java·开发语言·javascript·c++·人工智能·后端·python
一袋米扛几楼9812 小时前
【报错问题】彻底解决 TypeScript 报错 TS2769: No overload matches this call (JWT 篇)
linux·javascript·typescript
涵涵(互关)12 小时前
语法大全-only-writer-two
前端·vue.js·typescript
huangql52012 小时前
浏览器 Location API、History API、路由记录与支付跳转完全指南
前端