解决项目部署之后出现的Error: Cannot find module ‘@/views/xxx‘问题

这次项目在最后的部署阶段,需要部署一个测试服务器的环境,正常的环境是开发环境和生产环境,分别是‘development’和‘production’,这次了解到除了这两种还存在有‘test’,也就是测试环境。
在package.json中的配置如下:

"scripts": {
   "dev": "vue-cli-service serve",
   "prod": "vue-cli-service build",
   "test": "vue-cli-service build"
}

然后在服务器上进行npm run test打包之后,项目运行总是会出现Error: Cannot find module '@/views/xxx’的问题,当时在网上搜索大部分的答案说是需要把router路由模式修改成懒加载的模式,将

component: () => import ('@/views' + file)

改为

component: (resolve) => require(['@/views' + file], resolve)

但是这种方式了话,会直接影响到其他服务器的代码部署,同时因为项目的问题,会导致js代码渲染特别的慢,进入页面会有十几秒钟的空白状态,体验非常不好,所以就展开了深入研究。
通过研究之后发现,在node_modules里边webpack打包配置中,似乎对production生产环境进行了特殊的处理,而现在使用的test打包,会和production打包环境下的不一样,从而导致了一些特殊情况的发生,但是具体到底是为什么也没有了解清楚,没有看懂webpack的源码。
最终的解决方案就是让test部署模式尽量趋近于正常状态下的打包模式,于是在通过研究之后使用了mode配置,package.json修改之后的如下:

"scripts": {
   "dev": "vue-cli-service serve",
   "prod": "vue-cli-service build",
   "test": "vue-cli-service build --mode development"
}

通过mode配置,可以让当前的打包命令按照对应的模式进行打包
在这里插入图片描述
项目中配置了如上的文件,那么在使用- -mode development就会使test打包命令指向.env.development文件中对应的网络地址配置,到此问题就解决了。
当然我也尝试过配置 - -mode test,但是发现通过这种方式也会导致上边出现的Error: Cannot find module '@/views/xxx’问题。

  • 15
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
uncaught error: cannot find module '@/static/images/jf_ico.png' at app-view是一个未捕获的错误。该错误表示在文件app-view中无法找到模块'@/static/images/jf_ico.png'。 这个错误通常发生在使用Vue.js或其他前端框架时,由于路径配置或文件位置的问题导致无法找到所需的图像文件。在这种情况下,需要检查以下几个方面来解决这个问题: 1. 检查文件路径:确认文件'@/static/images/jf_ico.png'的实际位置是否与代码中的路径相匹配。路径可能会有拼写错误或者缺少某些目录,导致无法正确找到文件。 2. 检查文件存在性:确认图像文件'@/static/images/jf_ico.png'是否真的存在于指定的路径。如果文件不存在或者被误删,就会导致这个错误。 3. 检查文件引用方式:确保在代码中正确引用了图像文件。例如,在Vue组件中使用img标签并设置src属性来引用图像文件。确保引用路径正确,以便正确地加载图像。 4. 检查配置文件:如果使用了一些额外的配置文件,如webpack或其他构建工具的配置文件,需要确认相关的路径配置是否正确。有时,文件路径可能是通过配置文件进行管理的,错误的配置可能导致无法正确找到文件。 总之,解决这个错误的方法是先检查文件路径、存在性、引用方式以及配置文件中的路径配置。通过确认这些细节,可以找到并解决导致无法找到图像文件的问题,从而解决uncaught error: cannot find module '@/static/images/jf_ico.png' at app-view的错误。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值