return key.indexOf(‘index.js’) < 0
}).map(i => {
return i.match(re)[1]
})
菜单的展示我们也根据配置,从Awesome中选择构建菜单的图标项目即可。
菜单项的组件,是在Layout/Components/Sidebar/Item.vue进行修改,以适应Awesome图标的处理:
render(createElement, context) {
const { icon, title } = context.props
const vnodes = []
if (icon) {
// vnodes.push() // 使用自定义svg图标
// vnodes.push() // 使用内置element图标
vnodes.push()// 使用awesome图标
}
if (title) {
vnodes.push({(title)})
}
return vnodes
}
通过各个地方进行修改,我们就可以使用Awesome的图标集合了。
========================================================================
在前面随笔《循序渐进VUE+Element 前端应用开发(3)— 动态菜单和路由的关联处理》我介绍了用户动态配置的菜单资源,结合本系统的所有路由,实现菜单的显示外,还过滤了系统路由,实现可访问路由的管理,两者结合实现了系统有效的菜单和路由的控制。
前端通过接口动态获取菜单列表,通过菜单的名称和路由名称的对应关系,我们以菜单集合为对照,然后过滤本地所有静态路由的列表,然后获得用户可以访问的路由列表,设置动态路由给前端,从而实现了界面根据用户角色/权限的不同,而变化用户的菜单界面和可访问路由集合。
菜单路由处理的大概的操作过程如下所示:
前端界面的动态菜单、本地路由、菜单导航和可访问路由的几个概念如下所示。
在前端界面处理中,我们通过Element界面组件的方式展示动态菜单信息,并结合菜单和路由的关系,实现菜单跳转到对应视图的处理过程。
因此,系统管理里面的菜单信息配置界面中,菜单的Web地址,对应的是系统静态路由的名称,如下界面所示。
之前定义系统的路由信息格式如下所示:
// 定义本系统的所有路由,具体路由呈现经过菜单数据过滤
export const asyncRoutes = {
‘dashboard’: {
path: ‘/dashboard’,
component: Layout,
children: [{
path: ‘dashboard’,
name: ‘dashboard’,
component: () => import(‘@/views/dashboard/index’)
}]
},
‘product’: {
path: ‘/product’,
component: Layout,
children: [{
path: ‘/product’,
name: ‘product’,
component: () => import(‘@/views/Product/index’)
}]
},
… //省略部分
‘icon’: {
path: ‘/icon’,
component: Layout,
children: [{
path: ‘/icon’,
name: ‘icon’,
component: () => import(‘@/views/icons/index’)
}]
},
‘external-link’: {
path: ‘http://www.iqidi.com’,
name: ‘external-link’
}
}
有了这些准备,我们在用户登录系统后,就从后台获取对应的菜单列表。
在系统登录处理过程中,考虑到初始化的时候,如果用户是管理员admin,并且获取用户菜单为空,可以考虑使用预设的静态菜单资源,可以让用户先配置好权限菜单。
// 系统静态菜单
var staticmenus = await GetStaticMenus()
// console.log(menus)
// 如果用户是admin 并且角色集合中没有菜单,则使用静态菜单
var username = store.getters.name // 用户名
if (username === ‘admin’) {
if (!menus || typeof (menus) === ‘undefined’ || menus.length === 0) {
menus = staticmenus // 系统管理员,初始化的时候使用静态菜单
}
}
最后
最后写上我自己一直喜欢的一句名言:
世界上只有一种真正的英雄主义就是在认清生活真相之后仍然热爱它