美文网首页vue
后端管理系统开发(二):路由篇

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

作者: 冯文议 | 来源:发表于2021-04-13 23:27 被阅读0次

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

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

1 基础

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

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

1.1 路由

路由就是跳转。

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

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

1.2 router.push

如下示例:

// 字符串
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)

如下示例:

// 在浏览器记录中前进一步,等同于 history.forward()
router.go(1)

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

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

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

1.4 命名路由

router.push({ name: 'user', params: { userId: 123 } })

1.5 重定向

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

const router = new VueRouter({
  routes: [
    { path: '/a', redirect: '/b' }
  ]
})

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

const router = new VueRouter({
  routes: [
    { path: '/a', redirect: { name: 'foo' }}
  ]
})

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

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

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

别名:

const router = new VueRouter({
  routes: [
    { path: '/a', component: A, alias: '/b' }
  ]
})

1.6 路由传参

1.6.1 通过path传参

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

路由配置

{
  path: '/particulars/:id',
  name: 'particulars',
  component: particulars
}

传递参数

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

接收参数

this.$route.params.id

1.6.2 通过params传参

参数不会显示在URL上

页面刷新,数据会丢失

路由配置

{
  path: '/particulars',
  name: 'particulars',
  component: particulars
}

传递参数

this.$router.push({
  name: 'particulars',
  params: {
    id: id
  }
})

接收参数

this.$route.params.id

1.6.3 通过query传参

使用path来匹配路由,然后通过query来传递参数
这种情况下 query传递的参数会显示在url后面?id=?

路由配置

{
  path: '/particulars',
  name: 'particulars',
  component: particulars
}

传递参数

this.$router.push({
  path: '/particulars',
  query: {
    id: id
  }
})

接收参数

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 目录结构

.
└── 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 单独页

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


7 一级菜单

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 二级菜单

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 多级菜单

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')
      }
    ]
  }
]


多级菜单-效果示例

相关文章

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

    很久很久……以前,我们开始了vue-admin-pro之旅。通过 后端管理系统开发(一):登录篇[https://...

  • Node.js_后端路由(二)

    Node.js_后端路由(二) 接着上一篇Node.js_后端路由(一)进行改进优化,有困惑之处可以回头查漏补缺。...

  • Flutter开发 -- [16 - 路由导航]

    一. 路由管理 1.1. 认识Flutter路由 路由的概念由来已久,包括网络路由、后端路由,到现在广为流行的前端...

  • 后端管理系统开发(一):登录篇

    作为后端程序员,想写一个数据展示的系统,主要用于数据查询、数据展示,当然也有登录功能了,有没有比较快的方式呢,于此...

  • Vue3: 前端路由的概念和原理

    1、什么是路由 路由(英文:router)就是对应关系。路由分为两大类:① 后端路由② 前端路由 2、后端路由 后...

  • Vue路由/路由守卫

    一、前端路由和后端路由概念解释 二、路由的基本使用方式 三、常见引入路由组件的方式和区别 四、常见引入路由分类1....

  • 第三十一节:Vue路由:前端路由vs后端路由的了解

    1. 认识前端路由和后端路由 前端路由相对于后端路由而言的, 在理解前端路由之前先对于路由有一个基本的了解 路由:...

  • 路由

    1、路由的本质就是对应关系。 2、路由分为前端路由和后端路由。 3、后端路由根据不同的用户url请求,返回不同的资...

  • Vue前端路由

    1 - 后端路由和前端路由 路由是一个比较广义和抽象的概念,路由的本质就是对应关系,在开发中,路由分为:后端路由、...

  • JavaScript--路由

    1、路由 (扩展) 对应的开发者来说 路由是一个很重要的东西。(前端路由)(后端路由) 2、后端路由 根据对应的接...

网友评论

    本文标题:后端管理系统开发(二):路由篇

    本文链接:https://www.haomeiwen.com/subject/fcmhlltx.html