vue3 api加载权限路由报错 vue Invalid route component

最近想用vue3撸个基础后台方便后边接单啥的

用到了一个小技术 通过api动态加载路由,刚开始写的时候老是报错

vue Invalid route component
找了好多文档都没找道原因,后边看到某篇博客使用 $拼接参数,就试了一下 没想到可以了

现在复盘一下

我的原始操作

api请求的json 也是就模拟了一个api返回路由

xxx.json

[
  {
    "path": "/About",
    "name": "About",
    "component": "../views/About"
  }
]

router.js

import {createRouter, createWebHashHistory} from 'vue-router'
import NotFound from   "../views/NotFound.vue"
const routes = [
    {
        name: "Home",
        path: "/",
        component: () => import('../views/Home')
    },
//匹配所有没有匹配到的
    { path: '/:pathMatch(.*)*', name: 'NotFound', component: NotFound },
]

const router = createRouter({
    history: createWebHashHistory(),
    routes
})

在最后 添加这么两行

假装是请求回来的

import jj from "/public/tsconfig.json"
//添加到路由里
 jj.forEach((item) => {
     console.log(item)
     router.addRoute({
         path: item.path,
         name: item.name,
         component: () => import(item.component)
     })
 })

这个时候启动vue就报错了

vue Invalid route component
后边就修改模拟数据

[
  {
    "path": "/About",
    "name": "About",
    "component": "views/About"
  }
]

添加路由改成了

import jj from "/public/tsconfig.json"
jj.forEach((item) => {
    console.log(item.component)
    router.addRoute({

        path: item.path,
        component: () => import(`@/${item.component}`)
    })
})

这个时候就访问正常了
就是这一句

import(`@/${item.component}`)

源码 可以到这里下载 下载

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JwCode

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值