先抛出我的疑难:为什么 vue-cli sourcemap私有化部署 这个解决方案很少有人提,网上搜到的根本都是说sourcemap配置(开关和模式等根底配置)的货色,尽管说sourcemap私有化部署配置比拟好实现,但我在vue-cli4生成的我的项目中发现这里还是有个小坑的,故,以此记录
咱们先关上vue-cli 的文档看下相干配置
// vue.config.js
module.exports = {
// options...
productionSourceMap: true, // 默认是true,接管的是布尔值
}
哦?没了?没了,sourcemap publicPath?不存在!也就是咱们压根不能通过简略的批改配置做到私有化部署sourcemap的需要,那怎么办?必定是批改webpack配置了!用 SourceMapDevToolPlugin 啊!这里的具体用法我不再赘述,毕竟文档都贴出来了
OK,咱们开始吧……很快,咱们就写好了,如下
const webpack = require('webpack')
module.exports = {
productionSourceMap: true, // 默认是true,接管的是布尔值
chainWebpack: config => {
config.plugin('SourceMapDevToolPlugin')
.use(webpack.SourceMapDevToolPlugin).tap(args => {
return [{
filename: '[file].map',
publicPath: 'https://exmaple.com/',
moduleFilenameTemplate: 'source-map'
}]
})
}}
而后你兴奋的去运行 npm run build
……
可是你发现在打包后的js开端呈现两个sourcemap指向,这是不对的,而后你开始各种猜测,各种尝试,发现就是不行,要么这不行,要么那不行的(手动坏笑)
怎么办?
排查问题大法之审查webpack配置
vue-cli是开发工具,打包是基于webpack的,那咱们就去看webpack咯,看看vue-cli最终生成的webpack配置到底是什么,到底是哪里出错了不就能找到问题的起因了吗?那怎么办呢?好在cli提供了这样的命令,毕竟webpack的确配置太简单了
点击查看审查我的项目的 webpack 配置文档
运行 vue inspect --mode production > output.js
后咱们发现……咱们发现很多方才尝试的那么多为什么不胜利的起因,每个人尝试的都不同,我只说最后咱们遇到的问题吧——为什么会有两个sourcemap指向,对了,这里提一下在审查webpack配置时加上的 --mode production
如果咱们不加上这句那默认审查的配置就是 development
模式下的了,那你可能还是找不到起因,好了,咱们看下输入的配置
// output.js
{
// options...
devtool: 'source-map',
optimization: {
// options...
minimizer: [
new TerserPlugin({
// options...
sourceMap: true
})
}
},
plugins: [
// other plugins...
new SourceMapDevToolPlugin({
filename: '[file].map',
publicPath: 'https://example.com/',
moduleFilenameTemplate: 'source-map'
})
]
}
bingo,抛去css相干的sourcemap配置项,咱们看到这三个相干配置 devtool
: 此选项管制是否生成,以及如何生成sourcemap TerserPlugin
: 应用 terser 去压缩js代码的插件,相似 uglifyJSPlugin SourceMapDevToolPlugin
: 该插件实现了对 sourcemap 生成,进行更细粒度的管制。它能够 代替 devtool 选项
留神,SourceMapDevToolPlugin是代替devtool,而在咱们的配置里却是并存的,既有devtool也有SourceMapDevToolPlugin,所以导致呈现了两个sourcemap的指向
so? 怎么解决呢?干掉devtool?那是肯定的,你绝不能干掉SourceMapDevToolPlugin,因为咱们须要配置sourcemap的publicPath,而devtool是不反对的,怎么改呢?哈哈,祝贺你,你又遇到了一个新问题
cli-service之sourcemap相干的简略刨析
其实,咱们在排查两个sourcemap指向的时候就应该去翻看cli的源码了,实际上我自己就是这样的,而且这应该是比较简单的,但这须要你绝对相熟cli和webpack,而且我集体感觉间接去看webpack的配置对你的剖析、了解更好
很显然,通过 build
命令咱们晓得,第一工夫就应该去看 cli-service ,而vue-cli的配置里最相干的就是productionSourceMap了,那好,咱们间接在源码里全局搜productionSourceMap,而后,咱们看到
很显著productionSourceMap间接管制着devtool和Terser的sourcemap,也就是说咱们不能简略的通过将productionSourceMap设置为false而解决两个sourcemap指向的问题,我置信聪慧的你在最后肯定尝试过这个计划,但后果很显然是NO!而这就是起因,阐明一下,在应用SourceMapDevToolPlugin时肯定要将压缩插件的sourcemap设置为true,否则将不会生成sourcemap,更谈不上对sourcemap的更细粒度的管制了
当然,这里我带大家饶了一段路,其实在上一步,怎么干掉devtool时,肯定有人想到间接通过 configureWebpack或chainWebpack
批改webpack配置就行了,实际上我晓得的最简略的的确如此,但写了这么一段是因为我想带你们和我一块看看,哈哈,毕竟多看看又没害处,或者你有播种呢
配置计划
const webpack = require('webpack')
module.exports = {
productionSourceMap: process.env.NODE_ENV === 'production',
chainWebpack: config => {
config.devtool(false)
if (process.env.NODE_ENV === 'production') {
config.plugin('SourceMapDevToolPlugin')
.use(webpack.SourceMapDevToolPlugin).tap(args => {
return [{
filename: '[file].map',
publicPath: 'https://exmaple.com/',
moduleFilenameTemplate: 'source-map'
}]
})
}
}}
发表回复