前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >后端管理系统开发(二):路由篇

后端管理系统开发(二):路由篇

原创
作者头像
冯文议
修改2021-04-15 10:27:21
1.2K0
修改2021-04-15 10:27:21
举报
文章被收录于专栏:编程笔记

很久很久……以前,我们开始了vue-admin-pro之旅。通过 后端管理系统开发(一):登录篇 ,实现登录功能,我们打开了后台管理系统的大门。本节是路由篇的讲解,不管管理系统如何简单,都少不了路由,所以,学习这一节,很有必要。不过呢,对于我们来说,路由就是菜单。

下面开始我们本节——路由篇的学习之旅。

1 基础

读这篇文章的,我相信大多数都是后端开发人员,可能有些学过Vue,也可能没有,所以在之前,我们先一起学习下路由相关的知识。

如果你想了解更多,看:Vue Router

1.1 路由

路由就是跳转。

声明式:<router-link :to="...">

编程式:router.push(...)

1.2 router.push

如下示例:

代码语言:txt
复制
// 字符串
router.push('home')

// 对象
router.push({ path: 'home' })

// 命名的路由
router.push({ name: 'user', params: { userId: '123' }})
router.push({ path: `/user/${userId}` }) // -> /user/123

// 带查询参数,变成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})

router.replace 不会向 history 添加新记录 = <router-link :to="..." replace>

1.3 router.go(n)

后退多少步,等于 window.history.go(n)

如下示例:

代码语言:txt
复制
// 在浏览器记录中前进一步,等同于 history.forward()
router.go(1)

// 后退一步记录,等同于 history.back()
router.go(-1)

// 前进 3 步记录
router.go(3)

// 如果 history 记录不够用,那就默默地失败呗
router.go(-100)
router.go(100)

1.4 命名路由

代码语言:txt
复制
router.push({ name: 'user', params: { userId: 123 } })

1.5 重定向

重定向也是通过 routes 配置来完成,下面例子是从 /a 重定向到 /b

代码语言:txt
复制
const router = new VueRouter({
  routes: [
    { path: '/a', redirect: '/b' }
  ]
})

重定向的目标也可以是一个命名的路由:

代码语言:txt
复制
const router = new VueRouter({
  routes: [
    { path: '/a', redirect: { name: 'foo' }}
  ]
})

甚至是一个方法,动态返回重定向目标:

代码语言:txt
复制
const router = new VueRouter({
  routes: [
    { path: '/a', redirect: to => {
      // 方法接收 目标路由 作为参数
      // return 重定向的 字符串路径/路径对象
    }}
  ]
})

注意导航守卫并没有应用在跳转路由上,而仅仅应用在其目标上。在下面这个例子中,为 /a 路由添加一个 beforeEnter 守卫并不会有任何效果。

别名:

代码语言:txt
复制
const router = new VueRouter({
  routes: [
    { path: '/a', component: A, alias: '/b' }
  ]
})

1.6 路由传参

1.6.1 通过path传参

参数会显示在URL上,页面刷新,数据不会丢失。

路由配置

代码语言:txt
复制
{
  path: '/particulars/:id',
  name: 'particulars',
  component: particulars
}

传递参数

代码语言:txt
复制
//直接调用$router.push 实现携带参数的跳转
this.$router.push({
  path: `/particulars/${id}`,
})

接收参数

代码语言:txt
复制
this.$route.params.id
1.6.2 通过params传参

参数不会显示在URL上

页面刷新,数据会丢失

路由配置

代码语言:txt
复制
{
  path: '/particulars',
  name: 'particulars',
  component: particulars
}

传递参数

代码语言:txt
复制
this.$router.push({
  name: 'particulars',
  params: {
    id: id
  }
})

接收参数

代码语言:txt
复制
this.$route.params.id
1.6.3 通过query传参

使用path来匹配路由,然后通过query来传递参数

这种情况下 query传递的参数会显示在url后面?id=?

路由配置

代码语言:txt
复制
{
  path: '/particulars',
  name: 'particulars',
  component: particulars
}

传递参数

代码语言:txt
复制
this.$router.push({
  path: '/particulars',
  query: {
    id: id
  }
})

接收参数

代码语言:txt
复制
this.$route.query.id

1.7 完整导航解析流程

  1. 导航被触发。
  2. 在失活的组件里调用 beforeRouteLeave 守卫。
  3. 调用全局的 beforeEach 守卫。
  4. 在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
  5. 在路由配置里调用 beforeEnter
  6. 解析异步路由组件。
  7. 在被激活的组件里调用 beforeRouteEnter
  8. 调用全局的 beforeResolve 守卫 (2.5+)。
  9. 导航被确认。
  10. 调用全局的 afterEach 钩子。
  11. 触发 DOM 更新。
  12. 调用 beforeRouteEnter 守卫中传给 next 的回调函数,创建好的组件实例会作为回调函数的参数传入。

2 目录结构

代码语言:txt
复制
.
└── src
    └── router              	// 路由目录
        ├── before-close.js     // 页面关闭前需要做的操作,写在这里
        ├── index.js        	// 路由策略
        └── routers.js      	// 路由配置

3 标签

path

路劲

name

名字

meta

页面信息配置,这是一个对象

title

标题

hideInMenu

是否在菜单中隐藏,布尔类型,true:隐藏;false:显示。默认:显示。

component

组件

notCache

不要缓存

icon

图标

hideInBread

设为true后此级路由将不会出现在面包屑中

redirect

跳转

4 图标

你可以去 这里 筛选想要的图标

如果无法满足我们的需求,可以自定义图标。

自定义图标,需要在图标名称前加下划线 _

后面会用一个篇章,单独说自定义图标。

5 多语言

如果你的系统要支持多语言,首先你要开启多语言。

1:将 ./src/config/index.js 配置文件中的多语言支持开启: useI18n=true

2:多语言文件在 ./src/local 目录下。

6 单独页

代码语言:txt
复制
export default [
  {
    path: '/login',
    name: 'login',
    meta: {
      title: 'Login - 登录',
      hideInMenu: true
    },
    component: () => import('@/view/Login/Login')
  }
]

7 一级菜单

代码语言:txt
复制
export default [
  {
    path: '/tools_methods',
    name: 'tools_methods',
    meta: {
      hideInBread: true
    },
    component: Main,
    children: [
      {
        path: 'tools_methods_page',
        name: 'tools_methods_page',
        meta: {
          icon: 'ios-hammer',
          title: '工具方法',
          beforeCloseName: 'before_close_normal'
        },
        component: () => import('@/view/tools-methods/tools-methods.vue')
      }
    ]
  },
]

8 二级菜单

代码语言:txt
复制
export default [
  {
    path: '/components',
    name: 'components',
    meta: {
      icon: 'logo-buffer',
      title: '组件'
    },
    component: Main,
    children: [
      {
        path: 'tree_select_page',
        name: 'tree_select_page',
        meta: {
          icon: 'md-arrow-dropdown-circle',
          title: '树状下拉选择器'
        },
        component: () => import('@/view/components/tree-select/index.vue')
      },
      {
        path: 'count_to_page',
        name: 'count_to_page',
        meta: {
          icon: 'md-trending-up',
          title: '数字渐变'
        },
        component: () => import('@/view/components/count-to/count-to.vue')
      }
    ]
  }
]
二级菜单-效果示例
二级菜单-效果示例

9 多级菜单

代码语言:txt
复制
export default [
  {
    path: '/multilevel',
    name: 'multilevel',
    meta: {
      icon: 'md-menu',
      title: '多级菜单'
    },
    component: Main,
    children: [
      {
        path: 'level_2_1',
        name: 'level_2_1',
        meta: {
          icon: 'md-funnel',
          title: '二级-1'
        },
        component: () => import('@/view/multilevel/level-2-1.vue')
      },
      {
        path: 'level_2_2',
        name: 'level_2_2',
        meta: {
          access: ['super_admin'],
          icon: 'md-funnel',
          showAlways: true,
          title: '二级-2'
        },
        component: parentView,
        children: [
          {
            path: 'level_2_2_1',
            name: 'level_2_2_1',
            meta: {
              icon: 'md-funnel',
              title: '三级'
            },
            component: () => import('@/view/multilevel/level-2-2/level-2-2-1.vue')
          },
          {
            path: 'level_2_2_2',
            name: 'level_2_2_2',
            meta: {
              icon: 'md-funnel',
              title: '三级'
            },
            component: () => import('@/view/multilevel/level-2-2/level-2-2-2.vue')
          }
        ]
      },
      {
        path: 'level_2_3',
        name: 'level_2_3',
        meta: {
          icon: 'md-funnel',
          title: '二级-3'
        },
        component: () => import('@/view/multilevel/level-2-3.vue')
      }
    ]
  }
]
多级菜单-效果示例
多级菜单-效果示例

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 基础
    • 1.1 路由
      • 1.2 router.push
        • 1.3 router.go(n)
          • 1.4 命名路由
            • 1.5 重定向
              • 1.6 路由传参
                • 1.6.1 通过path传参
                • 1.6.2 通过params传参
                • 1.6.3 通过query传参
              • 1.7 完整导航解析流程
              • 2 目录结构
              • 3 标签
                • path
                  • name
                    • meta
                      • title
                        • hideInMenu
                          • component
                            • notCache
                              • icon
                                • hideInBread
                                  • redirect
                                  • 4 图标
                                  • 5 多语言
                                  • 6 单独页
                                  • 7 一级菜单
                                  • 8 二级菜单
                                  • 9 多级菜单
                                  领券
                                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档