美文网首页
路由和菜单

路由和菜单

作者: Lucky_Xue | 来源:发表于2019-05-22 14:31 被阅读0次

路由和菜单是组织起一个应用的关键骨架,为了方便管理,使用了中心化的方式,在 router.config.js统一配置和管理。

基本结构

在这一部分,脚手架通过结合一些配置文件、基本算法及工具函数,搭建好了路由和菜单的基本框架,主要涉及以下几个模块/功能:

  • 路由管理 通过约定的语法根据在 router.config.js 中配置路由。
  • 菜单生成 根据路由配置来生成菜单。菜单项名称,嵌套路径与路由高度耦合。
  • 面包屑 组件 PageHeader 中内置的面包屑也可由脚手架提供的配置信息自动生成。

下面简单介绍下各个模块的基本思路

路由

目前脚手架中所有的路由都通过 router.config.js来统一管理,在 vue-router 的配置中我们增加了一些参数,如 hideChildrenInMenu,meta.title,meta.icon,meta.permission,来辅助生成菜单。其中:

  • hideChildrenInMenu 用于隐藏不需要在菜单中展示的子路由。用法可以查看 分步表单 的配置。
  • hidden 可以在菜单中不展示这个路由,包括子路由。效果可以查看 other 下的路由配置。
  • meta.titlemeta.icon分别代表生成菜单项的文本和图标。
  • meta.permission 用来配置这个路由的权限,如果配置了将会验证当前用户的权限,并决定是否展示 *(默认情况下)。
  • meta.hidden 可以强制子菜单不显示在菜单上(和父级 hideChildrenInMenu 配合)
  • meta.hiddenHeaderContent 可以强制当前页面不显示 PageHeader 组件中的页面带的 面包屑和页面标题栏

菜单

菜单根据 router.config.js生成,具体逻辑在 src/store/modules/permission.js 中的 actions.GenerateRoutes 方法实现。

需求实例

上面对这部分的实现概要进行了介绍,接下来通过实际的案例来说明具体该怎么做。

菜单跳转到外部地址

你可以直接将完整 url 填入 path 中,框架会自动处理。

{
    path: 'https://www.baidu.com',
    name: 'docs',
    meta: {
        title: '文档', 
        target: '_blank' // 打开到新窗口
   }
}

加好后,会默认生成相关的路由及导航。

新增布局

在脚手架中我们通过嵌套路由来实现布局模板。router.config.js 是一个数组,其中第一级数据就是我们的布局,如果你需要新增布局可以再直接增加一个新的一级数据。

{
    path: '/new-router',
    name: 'newRouter',
    redirect: '/new-router/ahaha',
    component: RouteView,
    meta: { title: '仪表盘', keepAlive: true, permission: [ 'dashboard' ] },
    children: [
    {
        path: '/new-router/ahaha',
        name: 'ahaha',
        component: () => import('@/views/dashboard/Analysis'),
        meta: { title: '分析页', keepAlive: false, permission: [ 'ahaha' ] }
    }
}

路由配置项 E.g:

/**
 * 路由配置说明:
 * 建议:sider menu 请不要超过三级菜单,若超过三级菜单,则应该设计为顶部主菜单 配合左侧次级菜单
 *
 **/
 {
  redirect: noredirect,
  name: 'router-name',
  hidden: true,
  meta: {
    title: 'title',
    icon: 'a-icon',
    keepAlive: true,
    hiddenHeaderContent: true,
  }
}

API

{ Route } 对象

参数 说明 类型 默认值
hidden 控制路由是否显示在 sidebar boolean false
redirect 重定向地址, 访问这个路由时,自定进行重定向 string -
name 路由名称, 必须设置,且不能重名 string -
meta 路由元信息(路由附带扩展信息) object {}
hideChildrenInMenu 强制菜单显示为Item而不是SubItem(配合 meta.hidden) boolean -

{ Meta } 路由元信息对象

参数 说明 类型 默认值
title 路由标题, 用于显示面包屑, 页面标题 *推荐设置 string -
icon 路由在 menu 上显示的图标 [string,svg] -
keepAlive 缓存该路由 boolean false
hidden 用于隐藏菜单时,提供递归到父菜单显示 选中菜单项(可参考 个人页 配置方式) boolean false
hiddenHeaderContent *特殊 隐藏 PageHeader 组件中的页面带的 面包屑和页面标题栏 boolean false
permission 与项目提供的权限拦截匹配的权限,如果不匹配,则会被禁止访问该路由页面 array []

路由自定义 Icon 请引入自定义 svg Icon 文件,然后传递给路由的 meta.icon 参数即可

请注意 component: () => import('..') 方式引入路由的页面组件为 懒加载模式。具体可以看 Vue 官方文档
增加新的路由应该增加在 ‘/‘ (index) 路由的 children
无需控制权限的路由或者需要在未登录情况访问的路由,可以定义在 /src/config/router.config.js 下的 constantRouterMap 属性中
permission 可以进行自定义修改,只需要对这个模块进行自定义修改即可 src/store/modules/permission.js

相关文章

  • 路由和菜单

    路由和菜单是组织起一个应用的关键骨架,为了方便管理,使用了中心化的方式,在 router.config.js统一配...

  • Ant Design Pro Vue使用心得

    目录结构 路由和菜单 基本结构 路由和菜单是组织起一个应用的关键骨架,pro 中的路由为了方便管理,使用了中心化的...

  • vue 权限菜单

    当路由和菜单都由后台返回时,菜单和路由的格式根据实际情况和后台商量返回。 整体流程如下1、在router.js中只...

  • The second day of the react proj

    注册路由 admin.js 后台管理的路由组件 导航菜单配置: config/menuConfig.js 导航菜单...

  • Vue 默认展开路由所在的菜单

    默认展开路由所在的菜单

  • Sword框架

    一,配置路由 1,设置路由路径 2,设置菜单,按钮(本地) 3,设置菜单显示内容(国际化) 二,接口访问 1,设置...

  • 微信小程序下拉菜单

    有兴趣可以看我的另一篇 vue菜单权限(路由和菜单都由后台返回)https://www.jianshu.com/p...

  • 路由-菜单-权限

  • UI组件模块设计思路

    模块设计思路 功能职责细分 UI组件 组件类型 如何创建组件 菜单获取 菜单缓存管理 菜单路由跳转 组件流式布局 ...

  • 动态生成一级菜单

    在 rbac 的基础上继续 流程 告诉机器那些路由可以作为菜单修改表结构 将这些可以作为菜单的路由,单独储存起来将...

网友评论

      本文标题:路由和菜单

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