如何实现动态路由权限

首先配置路由表,创建函数并且导出,设置一个状态,默认false没有添加新的路由,递归遍历菜单,在下面调用递归函数传入菜单,根据菜单的frontpath属性找到对应的路由,返回一个值,这个值是路由项,判断如果路由表中没有这个路由,就使用router.addRoute添加到路由表中,将设置的状态改为true,判断如果有子菜单并目子菜单长度大于0,递归遍历子菜单传入子菜单,然后进设置的状态return出去,在路由鉴权里面初始值一个状态,在判断有token的情况下,动态添加路由

// 添加动态路由
export function addRouter(menus) {
    // 定义一个变量
    let hasNewRouter = false
    // 定义一个递归函数
    const findAndRouterByMenu = (arr) => {
        // 遍历数组
        arr.forEach((e) => {
            // 查找路由表里面有没有这个路由
            let item = MunsRouter.find((o) => o.path === e.frontpath)
            // 如果有这个路由并且路由表里面没有这个路由
            if (item && !router.hasRoute(item.path)) {
                router.addRoute('admin', item)  // 添加路由
                hasNewRouter = true
            }
            // 如果有子路由 递归添加
            if (e.child && e.child.length > 0) {
                findAndRouterByMenu(e.child)
            }
        })
    }
    // 调用递归函数
    findAndRouterByMenu(menus)
    // 返回是否有新路由
    return hasNewRouter
}


// 前置路由守卫
router.beforeEach(async (to, from, next) => {
    // 如果没有token并且跳转的不是登录页
    let token = getToken()
    if (!token && to.path !== '/login') {
        toast('请先登录', 'error')
        return next({ path: '/login' })
    }

    // 如果有token并且跳转的是登录页
    if (token && to.path == '/login') {
        toast('请误重新登录', 'error')
        return next({
            path: from.path ? from.path : '/'
        })
    }
    // 如果有token
    // 定义一个变量
    let hasNewRouter = false
    if (token) {
        // 获取用户信息
        let { menus } = await store.dispatch('SET_USER')
        // 添加动态路由
        hasNewRouter = addRouter(menus)
    }
    // 如果有token并且跳转的不是登录页 
    hasNewRouter ? next(to.fullPath) : next()
})

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值