12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- const path = require('path')
- const CompressionPlugin = require('compression-webpack-plugin')
- function resolve(dir) {
- return path.join(__dirname, dir)
- }
- const port = process.env.port || process.env.npm_config_port || 80 // 端口
- // vue.config.js
- module.exports = {
- // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
- productionSourceMap: false,
- configureWebpack: (config) => {
- // 生产环境取消 console.log
- if (process.env.NODE_ENV === 'production') {
- config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
- }
- },
- 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'))
- // 生产环境,开启js\css压缩
- if (process.env.NODE_ENV === 'production') {
- config.plugin('compressionPlugin').use(
- new CompressionPlugin({
- test: /\.(js|css|less)$/, // 匹配文件名
- threshold: 10240, // 对超过10k的数据压缩
- deleteOriginalAssets: false, // 删除源文件
- })
- )
- }
- },
- css: {
- loaderOptions: {
- less: {
- modifyVars: {
- /* less 变量覆盖,用于自定义 ant design 主题 */
- 'primary-color': '#1890FF',
- 'link-color': '#1890FF',
- 'border-radius-base': '4px',
- },
- javascriptEnabled: true,
- },
- },
- },
- devServer: {
- host: '0.0.0.0',
- port: port,
- open: true,
- proxy: {
- [process.env.VUE_APP_BASE_API]: {
- target: 'http://localhost:8080', // 请求本地 需要jshERP-boot后台项目
- changeOrigin: true,
- pathRewrite: {
- ['^' + process.env.VUE_APP_BASE_API]: '',
- },
- },
- },
- disableHostCheck: true,
- },
- lintOnSave: false,
- }
|