vue动态设置路由权限的主要思路
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要给大家介绍了关于vue动态设置路由权限的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
之前看到网上有些动态设置路由的,跟目前的项目不是很匹配,就自己动手实现了一种。主要思路就是
1.配置路由的时候绑定好id,可后端开发完成后,与后端同步id就行,这id唯一不变,根据此id可找到路由地址及icon。
const routerArr = [ { path: '', name: '', ponent: () => import( / webpackChunkName: "strategiesMaintain" / '@/ponents/Layout/Index'), meta: { requireAuth: true, id: 1, icon: 'iconzhanghuguanli', title: '路由1' }, children: [{ path: '/verificationLog', name: 'VerificationLog', ponent: () => import( / webpackChunkName: "verificationLog" / '@/views/auditManage/verificationLog'), meta: { requireAuth: true, id: 101, icon: 'icon-disanfangyanzhengrizhi', title: '路由11' } }, { path: '/systemLog', name: 'SystemLog', ponent: () => import( / webpackChunkName: "systemLog" / '@/views/auditManage/systemLog'), meta: { requireAuth: true, id: 102, icon: 'icon-xitongcaozuorizhi', title: '路由12' } }] } ]; export default routerArr;
2.设置本地路由与后端传来的路由的联系,主要是根据id绑定路由地址及iconClass
import routerModules from "@/router/modules"; import {http} from '@/utils/http' import store from '@/store'; import { Message } from 'element-ui' const formateResData = (val) =>{ // 格式化路由数据 const obj = {}; const fn = (arr)=>{ for(let i = 0,item;item = arr[i++];){ obj[item['meta']['id']] = { path: item['path'], iconClass: item['meta']['icon'] }; if(item.children && item.children.length > 0){ fn(item.children); } } } fn(val); return obj; }; const MAPOBJ = formateResData(routerModules); const dealWithData = (navData) => { // 处理菜单数据 let firstLink = ""; const navIdArr = []; const fn = (arr) => { for (let i = 0,item;item = arr[i++];) { item['iconClass'] = MAPOBJ[item.id].iconClass; item['linkAction'] = MAPOBJ[item.id].path; navIdArr.push(item.id); if (!firstLink && !item.subMenu) { // 设置默认跳转 firstLink = item['linkAction']; } if (item.subMenu && item.subMenu.length > 0) { fn(item.subMenu); } } } fn(navData); return {navData,navIdArr,firstLink}; }; let navIds = []; const getNav = async (to={},from={},next=()=>{})=>{ // 获取导航数据 const {code,data} = await http("/menu/list", {}, "GET"); // 获取菜单数据 // const data = require("@/mock/api/menuData"); // 使用mock数据 const {navData,navIdArr,firstLink} = dealWithData(data); store.mit('setNavData', navData); navIds = navIdArr; if(to.fullPath == '/index'){ // 从登录过来 或者是回首页 next(firstLink); }else { // 刷新 if(navIds.indexOf(to.meta.id) == -1){ // 后端没有返回该菜单 Message.error('菜单不存在或者没有权限'); return; } next(); } } export const setGuard = (to={},from={},next=()=>{}) =>{ // 设置权限 if(navIds.length === 0){ // 还没有获取菜单数据 getNav(to,from,next); }else { // 获取到菜单数据 if(navIds.indexOf(to.meta.id) == -1){ // 后端没有返回该菜单 Message.error('菜单不存在或者没有权限'); return; } next(); } }
3.在mainjs中引入配置
router.beforeEach((to, from, next) => { let token = wlhStorage.get("authorization"); if (to.path == "/login") { storage.clear();// 清空缓存 next(); } else { if (to.meta.requireAuth && token) { // 登陆 setGuard(to,from,next); } else { // 没有登录 next("/login"); } } })
到此这篇关于vue动态设置路由权限的文章就介绍到这了,更多相关vue动态设置路由权限内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
上一篇:原生JavaScript实现随机点名表
下一篇:Java 生成随机字符的示例代码
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南