基于iview-admin实现动态路由的示例代码-创新互联
iview-admin是一个基于vue和iview组件库实现的管理后台前端,本文基于iview-admin最新版本,实现基于权限的动态路由加载。

本文代码可参见:https://github.com/MayBeWrong/iview-admin-dynamic-router
背景:
动态路由:vue的路由,可通过new Router传入路由数组定义实现,也可以通过router.addRoutes实现。通过router.addRoutes动态传入路由定义的方式,称之为动态路由。路由数据可以全部保存在后台数据库中,也可以将路由配置在前端,后端返回给前端路由权限信息,然后匹配过滤,进行加载。本文就这两种方式分别进行介绍,并且给出实现参考。
目标:
基于iview-admin最新代码,实现两种不同的路由动态加载方式:
- 路由(导航菜单)数据全部存储在后台
- 路由数据配置在前端,后台只存储权限信息
注意:本文通过Mock模拟后端接口
方式1:路由(导航菜单)数据全部存储在后台
定义路由数据结构体,在文件中:src/mock/data.js
export const routersData = [{
path: '/pet',//访问路径
name: 'Pet',//路由的名字,这个与i18n有关,需要唯一
meta: {
title: '宠物',//标题
hideInMenu: false,//是否在左侧导航菜单隐藏
icon: 'logo-freebsd-devil'//图标
},
component: 'components/main',//组件文件路径,不需要Import
children: [{//嵌套路由
path: 'cat',
name: 'Cat',
meta: {
title: '猫咪',
hideInMenu: false,
icon: 'ios-cloudy-night'
},
component: 'view/pet/cat/Cat.vue'
}, {
path: 'dog',
name: 'Dog',
meta: {
hideInMenu: false,
title: '狗娃',
icon: 'ios-color-filter'
},
component: 'view/pet/dog/Dog.vue'
}, {
path: 'pig',
name: 'Pig',
meta: {
hideInMenu: false,
title: '猪啊',
icon: 'ios-contact'
},
component: 'view/pet/pig/Pig.vue',
children: [
{
path: 'female',
name: 'Female',
meta: {
hideInMenu: false,
title: '母猪',
icon: 'ios-contact'
},
component: 'view/pet/pig/Pig.vue',
},
{
path: 'male',
name: 'Male',
meta: {
hideInMenu: false,
title: '公猪',
icon: 'ios-contact'
},
component: 'view/pet/pig/Pig.vue',
}
]
}]}]
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
文章题目:基于iview-admin实现动态路由的示例代码-创新互联
网站路径:http://www.scyingshan.cn/article/dggcjc.html


咨询
建站咨询
