记一次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

相关文章

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

SpringBoot+Vue3整合SSE实现实时消息推送功能

《SpringBoot+Vue3整合SSE实现实时消息推送功能》在日常开发中,我们经常需要实现实时消息推送的功能,这篇文章将基于SpringBoot和Vue3来简单实现一个入门级的例子,下面小编就和大... 目录前言先大概介绍下SSE后端实现(SpringBoot)前端实现(vue3)1. 数据类型定义2.

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

java反序列化serialVersionUID不一致问题及解决

《java反序列化serialVersionUID不一致问题及解决》文章主要讨论了在Java中序列化和反序列化过程中遇到的问题,特别是当实体类的`serialVersionUID`发生变化或未设置时,... 目录前言一、序列化、反序列化二、解决方法总结前言serialVersionUID变化后,反序列化失

MySQL 5.7彻底卸载与重新安装保姆级教程(附常见问题解决)

《MySQL5.7彻底卸载与重新安装保姆级教程(附常见问题解决)》:本文主要介绍MySQL5.7彻底卸载与重新安装保姆级教程的相关资料,步骤包括停止服务、卸载程序、删除文件和注册表项、清理环境... 目录一、彻底卸载旧版本mysql(核心步骤)二、MySQL 5.7重新安装与配置三、常见问题解决总结废话不多