当路由信息全部由后台返回时,基于之前的路由遍历开发

当路由信息完全由后台提供时,可能会遇到组件引用问题。本文介绍了如何通过创建一个JS文件来映射这些路由,将路由信息存储在Vuex中,并在main.js中设置路由拦截器。虽然方案简洁,但对某些细节处理仍有优化空间,欢迎讨论。
摘要由CSDN通过智能技术生成

路由权限表全部由后台返回时,会出现component指向问题,可新建一个js文件,用来映射,如下

js

var map = new Map()

map.set("index", () =>
    import ('@/views/index.vue'))
map.set("h1", () =>
    import ('@/index/home1.vue'))
map.set("h2", () =>
    import ('@/index/home2.vue'))


console.log("执行了")

function getRouterList() {
    //登录之后获取动态路由
    let userRouter = JSON.parse(unescape(localStorage.getItem('roleinfo')))
    digui(userRouter)

    function digui(userRouter) { //递归,将后台传来的字符串组件名指向本地组件
        userRouter.forEach(function(value, index, array) {
            if (array[index].children && array[index].children != null) {
                digui(array[index].children)
            }
            array[index].component = map.get(array[index].component) //遍历,通过映射找到我们定义好的组件
        })
    }
    return (userRouter);
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值