Vue自定义页面路由
  CAROyoyNhr19 2023年11月24日 24 0

错误1:webpackEmptyContext (eval at ./src/store/modules sync recursive (0.js:10), <anonymous>:2:10)

路由信息由后端给出,那么前端需要动态加载路由,同时component的路径也是后端给出,但是动态加载该路径会报错

// 假如path = '@/views/user'
const com = () => import(path) // 这样会报错哦
 
const com2 = () = > import('@/views/user') // 这样写死的字符串就可以

  

原因应该是在webpack,webpack 编译es6 动态引入 import() 时不能传入变量,因为webpack的现在的实现方式不能实现完全动态。

解决办法:

可以通过字符串模板来提供部分信息给webpack,例如import(`@/${path}`), 这样编译时会编译所有@/views下的模块,但运行时确定path的值才会加载,从而实现懒加载。

如果写了@给webpack还是不能识别,那么可能你需要多些几级的路径,如import(`@/views/${path}`)

 

错误2:Syntax Error: TypeError: Cannot read property 'range' of null

解决方案

  1、问题原因为babel-lint版本过高问题导致。

解决方式:降低版本,比如7/8都可以。

 

修改package.json

 

...
	"devDependencies": {
			...
	    "babel-eslint": "^7.2.3",
	     ...
     }

    1、调整页面路由页面导入方式

//【component = () => import(`@/views${item.path}`)】这个地方用这种方式有时报错,解决方案使用【component = resolve => require([`@/views${item.path}`], resolve)】
      component = resolve => require([`@/views${item.path}`], resolve)

  

 



【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

上一篇: VUE组件使用 下一篇: VS Code环境配置
  1. 分享:
最后一次编辑于 2023年11月24日 0

暂无评论

推荐阅读
CAROyoyNhr19