前言
filemanager-webpack-plugin插件的使用方法:vue-cli@3.0 直接打包成zip压缩文件
正文
使用"npm i"命令安装所有依赖,然后使用“npm run serve”命令运行本地服务器,但是不能正常启动,报以下错误:

原因
项目使用了叫作filemanager-webpack-plugin的webpack插件,目的是为了在进行打包的时候,直接把打包结果dist文件夹压缩,变成dist.zip文件。

调用代码位于vue.config.js下:

const FileManagerPlugin = require('filemanager-webpack-plugin')
module.exports = {configureWebpack: {  plugins: [new FileManagerPlugin({  onEnd: {delete: [   './dist.zip',],archive: [ {source: './dist', destination: './dist.zip'},]}})]}};

代码的本意是想在调用“npm run build”进行生产打包的时候,生成dist.zip压缩包。

但是事实上发现,在运行“npm run serve”进行调试时,也会根据dist文件夹,去生成压缩包。而如果是从git远程库新clone下来的代码,默认是没有dist文件夹的(一般项目都会在.gitignore里,把dist文件夹设为不推送到远程库),导致filemanager-webpack-plugin因找不到dist文件夹而报错。
解决

mkdir: ['./dist']

即在生成dist.zip压缩包之前,先自动创建一个空的dist文件夹,防止因为找不到dist文件夹而报错。这样做,也不会对生产打包造成影响,此时的dist就是包含了打包内容的正常文件夹了。

感觉以后在使用这个插件进行压缩时,不能照抄网上的教程了,得使用一下这个改进后的配置。

当然如果有更好的方法,欢迎指教。
想出解决方法的思维过程
在出现这个报错时,曾经一度怀疑是安装依赖出了问题。因为旧项目文件夹是能正常本地运行的,咋眼看去新旧项目文件夹唯一的不同,就是node_modules文件夹了。

但是无论是使用“npm i”进行正常安装,还是使用“npm ci”进行锁版安装,全都没用。最后被逼无奈,只好把旧项目文件夹里的node_modules文件夹,直接拷贝到新项目文件夹里,但是依然报出同样的错误。

在与同事一起交流探讨之后,不经意把注意力放到了dist.zip压缩包上。

因为我们是从远程库新clone下来的项目,dist.zip这个压缩文件,肯定不是我们之前推送到远程库的,那么它到底是怎么产生的?

把它删掉之后,重新运行“npm run serve”命令,发现它是在这个过程产生的。于是我开始逐渐把视角放到了“安装”之外:依赖报错,难道一定就是依赖安装得不对吗?当然不是,在调用依赖的时候,如果我们配置不当或者调用不当,不是也会报错吗?
(只是我们脑海中一直有种固有观念:能够被大众广泛使用的东西,一定做了异常处理,就算不能达到我们预想的效果,但至少也不可能报错)

这样一来原因就逐渐明朗了。既然有压缩,那必然要存在原文件夹,如果原文件夹不存在,是不是就会报错?为新项目手动添加了一个dist文件夹后,再执行“npm run serve”,果然不报错了。

那么解决办法也就清楚了,同样利用filemanager-webpack-plugin插件,我们就每次在压缩前,先给它生成一个dist文件夹,以防不测就好了。

后文
按理说 在运行“npm run serve” 的时候,我们并不想打包,这时不应该要去做压缩dist的操作。网上查到的不少相关配置教程有问题,有些违反我们的常理和预期。

这并非插件本身的错,而在于我们使用者使用得不当。如果我们对webpack以及其插件有更深入的了解的话,大概能配置出更好的自动化构建流程吧。

从解决这个异常的过程中,大概学到了:
1)依赖报错,不要光认为是“安装”这一过程出了问题。配置和使用也可能是导致异常的原因。
2)多交流,就算不能从他人身上直接得到解决办法,也许也能得到一丝灵感、或者能够获得另外一种视角。自己一人瞎想,可能就会一直在死胡同徘徊。
————————————————
原文链接:https://blog.csdn.net/TheJormangund/article/details/108435897

打包filemanager-webpack-plugin的报错和解决相关推荐

  1. XXX@1.0.0 build: `NODE_ENV=production webpack --config webpack.config.js`报错的解决

    1.我们先来分析一下这个报错的原因: 在build这个项目的时候失败 2.检查一下我是怎么配置的build 在项目中我使用了NODE_ENV=development的设置方式,而多数的windows不 ...

  2. vue-cli打包构建时常见的报错解决方案

    vue-cli打包构建时常见的报错解决方案 参考文章: (1)vue-cli打包构建时常见的报错解决方案 (2)https://www.cnblogs.com/bester-ace/articles/ ...

  3. 解决vue-pdf 打包后生成worker文件报错问题

    解决vue-pdf 打包后生成worker文件报错问题 安装 vue-pdf npm install --save vue-pdf 进入目录 node_modules/worker-loader/di ...

  4. uniapp 云打包后IOS白屏,真机调试也是白屏,没有报错!解决办法

    uniapp 云打包后IOS白屏,真机调试也是白屏,没有报错!解决办法! 原来用uniapp 写的小程序 然后要翻成app 一开始还是很顺利的,因为安卓端测试 没有什么大问题:但是IOS直接白屏,只能 ...

  5. GitLabCICD实战----在.gitlab-ci.yml文件的步骤中使用git clone 另一个代码仓报错的解决办法

    更多信息请关注 个人网站 一.背景 在有些时候,比如在一个项目中,产品的代码是java代码仓,自动化测试脚本是python语言,单独存放的代码仓,在使用GitlabCICD构建流水线的时候有这样一种场 ...

  6. 创建Vue脚手架并启动出现的报错及解决(总冠军版)

    一.赛前准备 准备工作与启动react脚手架不能说相同只能说一摸一样,具体可见 创建react项目并启动出现的报错及解决. 二.正式比赛(勇士总冠军今天!!) 1.全局安装: npm install ...

  7. vue项目Error: Cannot find module ‘xxx’类报错的解决方法

    现发现只要是报错 Error: Cannot find module 'xxx'(例如 Error: Cannot find module 'webpack')这类的问题都可以用下面的方法解决. 报错 ...

  8. maven插件报错之解决

    maven插件报错之解决 用m2eclipse创建Maven项目时报错 maveneclipsebuilddependenciesauthorizationplugins 用m2eclipse创建 ...

  9. windows10下,from skimage import morphology 报错的解决办法

    windows10下,from skimage import morphology 报错的解决办法 报错原因 没有安装numpy+mkl库 解决方法 卸载skimage pip uninstall s ...

最新文章

  1. 发布一个Python小程序:ManHourCalendar
  2. win7硬盘安装ubuntu双系统——注意项
  3. hadoop分布式搭建
  4. js课程 5-14 js如何实现控制动画角色走动
  5. 一步步的教新手如何在一台物理机上部署红帽和win7双系统 ...
  6. Mybatis的修改列与重命名
  7. @interface CTDataFactoryViewController : CTMessageViewController
  8. chromium 源码下载地址
  9. Spring Boot 之Spring data JPA简介
  10. ML《集成学习(三)Boosting和Adaboosting回归树》
  11. tkinter使用cefpython库_Python3.7 tkinter中嵌入网页(WebView),需要引入cefpython3
  12. python之集合操作
  13. FireFox nsSessionStore.js 问题报错解决
  14. 一、安装Windows 2012域控(For SQLServer 2014 AlwaysOn)
  15. linux网络总线的作用,I2C总线是什么?基于I2C总线的Linux系统有哪些优点?
  16. mate7 android升级包下载,华为mate7 刷机包
  17. 基于Fragstats的土地利用景观格局分析
  18. 移动端html页面显示图表,HTML5移动端数据图表组件调研
  19. 26款免费原型设计工具,总有一款适合你
  20. 赴美工作常识(Part 5 - 绿卡优先级)

热门文章

  1. MongoDB 基础教程CURD帮助类
  2. 0728pm 控制器
  3. 解决rspec 生成报告时报utf-8错误的方法
  4. [z]IE6各种不兼容问题
  5. Immutable 想破坏它也没办法
  6. 利用Reachability实现网络状态监听
  7. linux清理swap内容,Linux如何清理swap.buffer及cache等缓存
  8. ad 原理图差分线_再改原理图,得加钱检查原理图PCB系列教程17
  9. equals变量在前面和后面的区别,equals已知(存在实际值)的变量在前的好处
  10. php 输出答案,php 如何只输出最后生成的那个值??