vue路由拦截案例

在根目录下创建一个permssion.js

在mainjs里面引入

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import '@/styles/index.scss'

import * as filters from './filters/index'
Vue.use(ElementUI);

import './permission' //引入路由拦截

Vue.config.productionTip = false

//全局过滤器
Object.keys(filters).forEach(key=>{
  Vue.filter(key,filters[key])
})

new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')

import router from './router'
import store from './store'

//路由拦截  路由在跳转前执行。。。
//beforeEach 有三个参数
//to 即将进入的路由
//from 即将离开
//next 下一个  管道钩子
router.beforeEach(async(to,from,next)=>{
    //1、是否是登录页
    if(to.path=='/login'){
        next();
    }else {
        //2、登录用户信息(分角色  管理员  销售人员  初审人员)
        //正常跳转   vuex中获取角色信息
        var hasRoles = store && store.getters.roles && store.getters.roles.length>0;
        console.log(111);
        if(hasRoles){
            next() //有角色  跳出拦截  
        }else {
            try{ //页面刷新 第一次登录
                let {roles} = await store.dispatch('USERINFO');  //获取用户详情
                //roles: [{id: 1, name: "administrator"}]  管理员administrator  销售input 审核approve
                let roleName = roles.map(n =>n.name); //取出name属性
                //传入对应的角色,返回路由的结果
                let asyncRoutes = await store.dispatch('GENERATEROUTES',roleName);
                console.log(asyncRoutes);
                router.addRoutes(asyncRoutes); //动态路由  接受的参数是数组对象
                console.log(222);
                if(roles){
                    next({...to});
                }else {
                    next({path:'/login'});
                }
            } catch(error){
                console.log(444);
                next({path:'/login'})
            }
        }
    }
    
    
    //没有角色  页面刷新 拿到用户信息   回到登录
    
})


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值