const path = require('path')
const CompressionPlugin = require('compression-webpack-plugin')
function resolve(dir) {
return path.join(__dirname, dir)
}
// vue.config.js
module.exports = {
/*
Vue-cli3:
Crashed when using Webpack `import()` #2463
https://github.com/vuejs/vue-cli/issues/2463
*/
// 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
productionSourceMap: false,
// 多入口配置
// pages: {
// index: {
// entry: 'src/main.js',
// template: 'public/index.html',
// filename: 'index.html',
// }
// },
// 打包app时放开该配置
// publicPath:'./',
configureWebpack: config => {
// 生产环境取消 console.log
if (process.env.NODE_ENV === 'production') {
config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
config["performance"] = {
"maxEntrypointSize": 10000000,
"maxAssetSize": 30000000
}
}
},
chainWebpack: (config) => {
config.resolve.alias
.set('@$', resolve('src'))
.set('@api', resolve('src/api'))
.set('@assets', resolve('src/assets'))
.set('@comp', resolve('src/components'))
.set('@views', resolve('src/views'))
.set('@layout', resolve('src/layout'))
.set('@static', resolve('src/static'))
.set('@mobile', resolve('src/modules/mobile'))
// 生产环境,开启js\css压缩
if (process.env.NODE_ENV === 'production') {
config.plugin('compressionPlugin').use(new CompressionPlugin({
test: /\.(js|css|less)$/, // 匹配文件名
threshold: 10240, // 对超过10k的数据压缩
deleteOriginalAssets: false // 不删除源文件
}))
}
// 配置 webpack 识别 markdown 为普通的文件
config.module
.rule('markdown')
.test(/\.md$/)
.use()
.loader('file-loader')
.end()
// 编译vxe-table包里的es6代码,解决IE11兼容问题
config.module
.rule('vxe')
.test(/\.js$/)
.include
.add(resolve('node_modules/vxe-table'))
.add(resolve('node_modules/vxe-table-plugin-antd'))
.end()
.use()
.loader('babel-loader')
.end()
},
css: {
extract: process.env.NODE_ENV === 'production' ? {
ignoreOrder: true,
} : false,
loaderOptions: {
less: {
modifyVars: {
/* less 变量覆盖,用于自定义 ant design 主题 */
'primary-color': '#1890FF',
'link-color': '#1890FF',
'border-radius-base': '4px'
},
javascriptEnabled: true
}
}
},
devServer: {
port: 3000,
proxy: {
/* '/api': {
target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro', //mock API接口系统
ws: false,
changeOrigin: true,
pathRewrite: {
'/edu-boot': '' //默认所有请求都加了edu-boot前缀,需要去掉
}
}, */
'/edu-boot': {
target: 'http://localhost:8080', // 请求本地 需要edu-boot后台项目
ws: false,
changeOrigin: true
}
}
},
lintOnSave: undefined
}
vue 打包两次都不一样这个是什么原因
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答
相关推荐 更多相似问题
点击登录
提问题
悬赏问题
- ¥30 grid.newpage() 中的错误 (main.R#9): no active device and default getOption("device") is invalid
- ¥15 求一个超难的动态新增元素的 click 事件无效的解决办法。
- ¥20 怎么修改mediawiki允许上传的文件大小?
- ¥15 agrySEXPAYm 是毒吗
- ¥50 Java实现注册登录实现数据库增删改查功能,数据库至少两个表
- ¥20 求解R语言的数据分析问题
- ¥20 求GD32F105和305解除读保护方法教程
- ¥15 C++代码优化,复杂度太高,无法通过clang-tidy检查,用什么办法可以优=化
- ¥15 关于跨链隐私保护方案
- ¥15 node mongodb 根据id给子集合list添加对象 请问应该如何操作