温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么在vue项目中动态设置路由权限

发布时间:2021-01-13 16:55:36 来源:亿速云 阅读:460 作者:Leah 栏目:开发技术

这篇文章给大家介绍怎么在vue项目中动态设置路由权限,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1.配置路由的时候绑定好id,可后端开发完成后,与后端同步id就行,这id唯一不变,根据此id可找到路由地址及icon。

const routerArr = [  {  path: '',  name: '',  component: () => import( /* webpackChunkName: "strategiesMaintain" */ '@/components/Layout/Index'),  meta: {  requireAuth: true,  id: 1,  icon: 'iconzhanghuguanli',  title: '路由1'  },  children: [{   path: '/verificationLog',  name: 'VerificationLog',  component: () => import( /* webpackChunkName: "verificationLog" */ '@/views/auditManage/verificationLog'),  meta: {  requireAuth: true,  id: 101,  icon: 'icon-disanfangyanzhengrizhi',  title: '路由11'  }  }, {  path: '/systemLog',  name: 'SystemLog',  component: () => 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.commit('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项目中动态设置路由权限就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI