怎么在vue中利用iview实现动态路由和权限验证功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
<强>项目基础强>
- <李>
基础框架:iview组件库官方模板项目iview-admin的模板分支项目,此项目为iview-admin的基础框架代码。项目地址:iview-admin
李><强>实现逻辑强>
<强>动态路由控制加载强>
一般来说,动态路由控制分为两种:一种是将所有路由数据存储在本地文件中,然后从服务端获取用户的权限信息,在路由跳转时,添加权限判断钩子,如果用户前往的页面不在权限列表内,则禁止跳转。另一种则是本地只存储基本路由,如错误处理页面,无权限控制页面等,而权限路由则从服务器获取,服务器根据用户的权限下发相应的路由数据,客户端利用这些数据进行路由的动态生成和添加,本文采用的是第二种方法。
iview-admin项目将路由分为三种:
- <李>
不作为主要组件的子页面展示的页面路由,例如登录、404403等错误页面路由;
李> <李>作为主要组件的子页面展示但是不在左侧菜单显示的路由otherRouter,比如首页路由;
李> <李>作为主要组件的子页面展示并且在左侧菜单显示的路由appRouter;
李>拿到路由数据后,我们主要进行两部分操作,第一部分是遍历数据,利用组件异步加载的方法,加载每个路由节点对应的组件,之后利用<代码> router.addRoutes(路线)代码>完成路由列表的动态添加;第二部分是因为<代码> iview-admin> 代码框架下的页面标签和面包屑导航,需要遍历appRouter获取路由信息,所以我们也需要将路由数据存入vuex,以便全局访问。
需要特别注意的是,如果404页面为静态路由,那么第一次进入页面时,这时动态路由还未加载,找不到路由地址会默认跳转到404错误页,体验很差,所以404路由先不写入路由规则中,和动态路由一起加载。
主要代码实现如下:
数据请求及路由节点生成
//util.js//生成路由 时间=util.initRouter function (vm), { ,const constRoutes =, []; ,const otherRoutes =, []; ,//404路由需要和动态路由一起注入 ,const otherRouter =, [{ ,,路径:& # 39;/* & # 39; ,,名字:& # 39;错误- 404 & # 39; 元才能:{ ,,,标题:& # 39;404页面不存在& # 39; ,,}, ,,组件:& # 39;页面偷走了/404 & # 39; ,}]; ,//模拟异步请求 ,util.ajax (& # 39; menu.json& # 39;),然后(res =祝辞,{ var 才能;menuData =, res.data; util.initRouterNode才能(constRoutes, menuData); util.initRouterNode才能(otherRoutes, otherRouter);//,才能添加主界面路由 vm。美元才能store.commit (& # 39; updateAppRouter& # 39;,, constRoutes.filter (item =祝辞,item.children.length 祝辞,0));//,才能添加全局路由 vm。美元才能store.commit (& # 39; updateDefaultRouter& # 39;,, otherRoutes);//,才能刷新界面菜单 vm。美元才能store.commit (& # 39; updateMenulist& # 39;,, constRoutes.filter (item =祝辞,item.children.length 祝辞,0)); ,}); };//生成路由节点 时间=util.initRouterNode function (路由器,,数据),{ ,for (var item  of 数据),{ let 才能;menu =, Object.assign({},,项目); 时间=menu.component 才能;lazyLoading (menu.component); if 才能;(item.children ,,, item.children.length 祝辞,0),{ ,,menu.children =, []; ,,util.initRouterNode (menu.children, item.children); ,,}//才能添加权限判断 meta.permission 才能=,menu.permission ?, menu.permission :,空;//才能添加标题 meta.title 才能=,menu.title ?, menu.title :,空; menu.meta 才能=,元; ,} };
<>强动态加载组件强>
//lazyLoading.js export default (url),=祝辞()=祝辞进口(“@/视图/$ {url} .vue ') 商店缓存实现//app.js ,//动态添加主界面路由,需要缓存 updateAppRouter (状态,,路线),{ ,state.routers.push(…路线); ,router.addRoutes(路线); },//,动态添加全局路由,不需要缓存 updateDefaultRouter (状态,,路线),{ ,router.addRoutes(路线); },//,接受前台数组,刷新菜单 updateMenulist (状态,,路线),{=,,state.menuList 路线; }怎么在vue中利用iview实现动态路由和权限验证功能