peng
2026-03-18 af8a72f0f43279cfe778af0ba683917032d95746
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
const path = require('path')
const CompressionPlugin = require('compression-webpack-plugin')
const GenerateFilePlugin = require('generate-file-webpack-plugin')
 
function resolve(dir) {
  return path.join(__dirname, dir)
}
 
// vue-cli3
module.exports = {
  productionSourceMap: false, // 如果不需要生产环境的 source map,可以将其设置为 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
    }
  },
  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 !== 'development') {
      config.plugin('compressionPlugin').use(
        new CompressionPlugin({
          test: /\.(js|css|less)$/, // 匹配文件名
          threshold: 10240, // 对超过10k的数据压缩
          deleteOriginalAssets: false // 不删除源文件
        })
      )
    }
 
    if (process.env.NODE_ENV !== 'development') {
      // 生成config-online.js
      config.plugin('generateFilePlugin').use(
        new GenerateFilePlugin({
          file: 'config-online.js',
          content: `window._CONFIG = window._CONFIG ? window._CONFIG : {}
window._CONFIG['onlinePreviewDomainURL'] = '${process.env.PREVIEW_BASE_URL}'
window._CONFIG['staticDomainURL'] = '${process.env.STATIC_BASE_URL}'
window._CONFIG['domianURL'] = '${process.env.API_BASE_URL}'
`
        })
      )
 
      config.plugin('html').tap(args => {
        // 生产环境引入config-online.js
        args[0].configOnline = '/config-online.js'
        return args
      })
    }
 
    // 配置 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: {
    loaderOptions: {
      less: {
        modifyVars: {
          hack: `true; @import (reference) "${path.resolve(`src/assets/skin/my-skin.less`)}";`
        },
        javascriptEnabled: true
      }
    }
  },
 
  devServer: {
    port: 10086,
    open: true,
    host:"0.0.0.0"
    // public: '25.30.13.141:3000'
    // proxy: {
    //   '/cube': {
    //     target: 'http://localhost:8080', // 请求本地 cube后台项目
    //     ws: false,
    //     changeOrigin: true,
    //     pathRewrite: {
    //       '/cube': '' // 默认所有请求都加了cube前缀,需要去掉
    //     }
    //   }
    // }
  },
 
  lintOnSave: undefined
}