Vue Router嵌套路由children的用法有哪些细节需要注意?

2026-04-01 12:571阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1017个文字,预计阅读时间需要5分钟。

Vue Router嵌套路由children的用法有哪些细节需要注意?

目录简介使用场景官网网址示例路径配置用户页面(父页面)子路由的path前加/简介说明文本介绍说明Vue Router的嵌套路由用法。嵌套路由嵌套路由就是在父路由中嵌套子路由,子路由的path前需要加上父路由的path。

目录
  • 简介
    • 使用场景
    • 官网网址
  • 示例
    • 路由配置
    • 用户页面(父页面)
  • 子路由的path前加“/”

    简介

    说明

    本文介绍Vue Router的嵌套路由的用法。

    嵌套路由就是父路由里面嵌套他的子路由,父路由有自己的路由导航和路由容器(router-link、router-view),通过配置children可实现多层嵌套。(router-view必须要有,否则点击了router-link后,路径会变化,但页面不改变)。

    使用场景

    嵌套路由用于实现页中页效果。例如:

    • 用户页面中,有登录页面和注册页面,这两个页面通过标签切换。

    此时:用户页面是父路由,登录和注册页面是子路由

    • 后台管理页面中,布局都是同一套,只是中间的内容部分改变。(例如:vue-element-admin)
    • 此时:整个布局是父路由,中间的内容页面是子路由。

    官网网址

    router.vuejs.org/zh/guide/essentials/nested-routes.html

    示例

    需求:写一个用户页面,里边有登录页面和注册页面,这两个页面通过标签切换。

    路由配置

    router/index.js

    Vue Router嵌套路由children的用法有哪些细节需要注意?

    import Vue from 'vue' import VueRouter from 'vue-router' import User from '../views/user/User' import Login from '../views/user/Login' import Register from '../views/user/Register' Vue.use(VueRouter) const routes = [ { path: '/', name: 'Home', redirect: User }, { path: '/user', name: 'User', component: User, children: [ { path: 'login', name: 'Login', component: Login }, { path: 'register', name: 'Register', component: Register } ] } ] const router = new VueRouter({ routes }) export default router

    用户页面(父页面)

    User.vue

    <template> <div class="outer"> <h2>这是用户页面</h2> <router-link :to="{name: 'Login'}">登录</router-link> | <router-link :to="{name: 'Register'}">注册</router-link> <router-view></router-view> </div> </template> <script> export default { name: 'User' } </script> <style scoped> .outer { margin: 20px; border: 2px solid red; padding: 20px; } </style>

    登录页面(子页面)

    Login.vue

    <template> <div class="outer"> <h3>这是登录页面</h3> </div> </template> <script> export default { name: 'Login' } </script> <style scoped> .outer { margin: 20px; border: 2px solid blue; padding: 20px; } </style>

    注册页面(子页面)

    Register.vue

    <template> <div class="outer"> <h3>这是注册页面</h3> </div> </template> <script> export default { name: 'Register' } </script> <style scoped> .outer { margin: 20px; border: 2px solid blue; padding: 20px; } </style>

    测试

    访问:192.168.0.104:8080/

    结果:

    点击“登录”/“注册”:

    子路由的path前加“/”

    如果子路由的path的最前边有“/”,则不需要加父路由的路径即可访问此子组件。

    例如,修改上边的“路由配置”,将path: 'login',改为path: '/login',则登录页面可以这样访问:

    192.168.0.104:8080/#/login

    示例

    router/index.js:

    import Vue from 'vue' import VueRouter from 'vue-router' import User from '../views/user/User' import Login from '../views/user/Login' import Register from '../views/user/Register' Vue.use(VueRouter) const routes = [ { path: '/', name: 'Home', redirect: User }, { path: '/user', name: 'User', component: User, children: [ { path: '/login', name: 'Login', component: Login }, { path: 'register', name: 'Register', component: Register } ] } ] const router = new VueRouter({ routes }) export default router

    测试

    到此这篇关于VueRouter嵌套路由(children)的用法的文章就介绍到这了,更多相关VueRouter嵌套路由内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

    标签:用法

    本文共计1017个文字,预计阅读时间需要5分钟。

    Vue Router嵌套路由children的用法有哪些细节需要注意?

    目录简介使用场景官网网址示例路径配置用户页面(父页面)子路由的path前加/简介说明文本介绍说明Vue Router的嵌套路由用法。嵌套路由嵌套路由就是在父路由中嵌套子路由,子路由的path前需要加上父路由的path。

    目录
    • 简介
      • 使用场景
      • 官网网址
    • 示例
      • 路由配置
      • 用户页面(父页面)
    • 子路由的path前加“/”

      简介

      说明

      本文介绍Vue Router的嵌套路由的用法。

      嵌套路由就是父路由里面嵌套他的子路由,父路由有自己的路由导航和路由容器(router-link、router-view),通过配置children可实现多层嵌套。(router-view必须要有,否则点击了router-link后,路径会变化,但页面不改变)。

      使用场景

      嵌套路由用于实现页中页效果。例如:

      • 用户页面中,有登录页面和注册页面,这两个页面通过标签切换。

      此时:用户页面是父路由,登录和注册页面是子路由

      • 后台管理页面中,布局都是同一套,只是中间的内容部分改变。(例如:vue-element-admin)
      • 此时:整个布局是父路由,中间的内容页面是子路由。

      官网网址

      router.vuejs.org/zh/guide/essentials/nested-routes.html

      示例

      需求:写一个用户页面,里边有登录页面和注册页面,这两个页面通过标签切换。

      路由配置

      router/index.js

      Vue Router嵌套路由children的用法有哪些细节需要注意?

      import Vue from 'vue' import VueRouter from 'vue-router' import User from '../views/user/User' import Login from '../views/user/Login' import Register from '../views/user/Register' Vue.use(VueRouter) const routes = [ { path: '/', name: 'Home', redirect: User }, { path: '/user', name: 'User', component: User, children: [ { path: 'login', name: 'Login', component: Login }, { path: 'register', name: 'Register', component: Register } ] } ] const router = new VueRouter({ routes }) export default router

      用户页面(父页面)

      User.vue

      <template> <div class="outer"> <h2>这是用户页面</h2> <router-link :to="{name: 'Login'}">登录</router-link> | <router-link :to="{name: 'Register'}">注册</router-link> <router-view></router-view> </div> </template> <script> export default { name: 'User' } </script> <style scoped> .outer { margin: 20px; border: 2px solid red; padding: 20px; } </style>

      登录页面(子页面)

      Login.vue

      <template> <div class="outer"> <h3>这是登录页面</h3> </div> </template> <script> export default { name: 'Login' } </script> <style scoped> .outer { margin: 20px; border: 2px solid blue; padding: 20px; } </style>

      注册页面(子页面)

      Register.vue

      <template> <div class="outer"> <h3>这是注册页面</h3> </div> </template> <script> export default { name: 'Register' } </script> <style scoped> .outer { margin: 20px; border: 2px solid blue; padding: 20px; } </style>

      测试

      访问:192.168.0.104:8080/

      结果:

      点击“登录”/“注册”:

      子路由的path前加“/”

      如果子路由的path的最前边有“/”,则不需要加父路由的路径即可访问此子组件。

      例如,修改上边的“路由配置”,将path: 'login',改为path: '/login',则登录页面可以这样访问:

      192.168.0.104:8080/#/login

      示例

      router/index.js:

      import Vue from 'vue' import VueRouter from 'vue-router' import User from '../views/user/User' import Login from '../views/user/Login' import Register from '../views/user/Register' Vue.use(VueRouter) const routes = [ { path: '/', name: 'Home', redirect: User }, { path: '/user', name: 'User', component: User, children: [ { path: '/login', name: 'Login', component: Login }, { path: 'register', name: 'Register', component: Register } ] } ] const router = new VueRouter({ routes }) export default router

      测试

      到此这篇关于VueRouter嵌套路由(children)的用法的文章就介绍到这了,更多相关VueRouter嵌套路由内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

      标签:用法