关于vue-cli4无法配置自定义devtool选项的问题

本文主要是介绍关于vue-cli4无法配置自定义devtool选项的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题表现

vue.config.js中无法配置自定义devtool选项,无论是使用configureWebpack还是chainWebpack都无法改变source-map的类型。官方文档也没有提供相关的说明。

// vue.config.js
const Components = require('unplugin-vue-components/webpack')
const { ElementPlusResolver } = require('unplugin-vue-components/resolvers')
// 两种方式均无法更改devtool
module.exports = {configureWebpack: {devtool: "source-map",// 2021.10.26更新 ↓罪魁祸首plugins: [Components({resolvers: [ElementPlusResolver()]})]},chainWebpack: config => {config.devtool('source-map')}
}

问题原因

2021.10.26更新: 问题产生的原因不是vue-cli,而是element-ui提供的按需加载插件unplugin-vue-components/resolvers破坏了sourcemap,具体的原因不清楚,似乎插件作者也不是很有sourcemap方面的开发意愿。 总之遇到这个问题的话看一看有没有这个玩应吧。
在这里插入图片描述


本来下面这里写了一大通,最后发现不是这个原因,错怪尤老师了,对不起x 下面的都可以不用看了

vue-clinpm run serve时强制使用了'eval-cheap-module-source-map'

// @vue/cli-service/lib/commands/serve.js
// line: 51api.chainWebpack(webpackConfig => {if (process.env.NODE_ENV !== 'production' && process.env.NODE_ENV !== 'test') {// 注意这里:在npm run serve时强制使用了'eval-cheap-module-source-map'webpackConfig.devtool('eval-cheap-module-source-map')webpackConfig.plugin('hmr').use(require('webpack/lib/HotModuleReplacementPlugin'))// https://github.com/webpack/webpack/issues/6642// https://github.com/vuejs/vue-cli/issues/3539webpackConfig.output.globalObject(`(typeof self !== 'undefined' ? self : this)`)if (!process.env.VUE_CLI_TEST && options.devServer.progress !== false) {webpackConfig.plugin('progress').use(require('webpack/lib/ProgressPlugin'))}}})

截止目前(2021年10月26日),vue-cli的最新realese版本(v4.5.14)中,依旧存在这个问题。但是github的开源代码的dev分支已经修复此问题(查看代码),不知道什么时候会发布到正式版本中去。

解决方案

方案一: 手动修改node_modules/@vue/cli-service/lib/commands/serve.js:54, 将'eval-cheap-module-source-map'改为想要的模式。弊端是install之后可能需要再改一下,如果不在意source-map的话还是权衡一下利弊。

方案二: 使用vue-clidev分支源代码编译一份最新的来使用。


以上!まいど~


这篇关于关于vue-cli4无法配置自定义devtool选项的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也