记一次vue-cli3下filemanager-webpack-plugin的报错和解决

本文主要是介绍记一次vue-cli3下filemanager-webpack-plugin的报错和解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

//2022-01-05 更新

1)插件出新版本了,需要注意一些配置项字段差异。
2)有朋友指出了一个更好的方法。可以参见评论区

前言

附上一篇filemanager-webpack-plugin插件的使用方法:vue-cli@3.0 直接打包成zip压缩文件

因为对之前项目进行再次开发时,遇到了太多因维护引起的问题(满满的心智负担,导致San值严重下降。。( ′Д`))。

所以想尝试一下,重新git clone一次某vue项目,想从二次开发者的视角去窥探,看流程能不能顺利。果不其然,出了问题。

正文

项目是使用Vue-cli3建立的。之前本地的旧项目代码一直能够正常工作,但是重新clone一次之后,却报了错。

把项目代码重新“git clone”下来后,使用"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文件夹而报错。

解决

在插件的onEnd钩子里最前面,加一句:

mkdir: ['./dist']

变成这样:

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

即在生成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)多交流,就算不能从他人身上直接得到解决办法,也许也能得到一丝灵感、或者能够获得另外一种视角。自己一人瞎想,可能就会一直在死胡同徘徊。

这篇关于记一次vue-cli3下filemanager-webpack-plugin的报错和解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/855719

相关文章

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re