Blame view

ant-design-vue-jeecg/vue.config.js 2.94 KB
1
const path = require('path')
2
const CompressionPlugin = require("compression-webpack-plugin")
3
4
function resolve(dir) {
5
6
7
8
9
10
11
12
13
14
  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
   */
15
16
  // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
  productionSourceMap: false,
17
18
19
20
21
22
23
24
  // 多入口配置
  // pages: {
  //   index: {
  //     entry: 'src/main.js',
  //     template: 'public/index.html',
  //     filename: 'index.html',
  //   }
  // },
25
26
  //打包app时放开该配置
  //publicPath:'./',
27
  configureWebpack: config => {
28
    //生产环境取消 console.log
29
30
31
32
    if (process.env.NODE_ENV === 'production') {
      config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
    }
  },
33
34
35
36
37
38
39
40
  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'))
41
42
43
44
45
46
      .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({
47
          test: /\.(js|css|less)$/, // 匹配文件名
48
49
50
51
          threshold: 10240, // 对超过10k的数据压缩
          deleteOriginalAssets: false // 不删除源文件
        }))
    }
52
53
54
55
56
57
58
59

    // 配置 webpack 识别 markdown 为普通的文件
    config.module
      .rule('markdown')
      .test(/\.md$/)
      .use()
      .loader('file-loader')
      .end()
60
61
    // 编译vxe-table包里的es6代码,解决IE11兼容问题
62
63
64
65
66
67
68
69
70
71
    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()
72
73
74
75
76
77
78
79
  },

  css: {
    loaderOptions: {
      less: {
        modifyVars: {
          /* less 变量覆盖,用于自定义 ant design 主题 */
80
81
          'primary-color': '#1890FF',
          'link-color': '#1890FF',
82
          'border-radius-base': '4px',
83
        },
84
        javascriptEnabled: true,
85
86
87
88
89
90
91
      }
    }
  },

  devServer: {
    port: 3000,
    proxy: {
92
     /* '/api': {
93
94
95
96
97
98
        target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro', //mock API接口系统
        ws: false,
        changeOrigin: true,
        pathRewrite: {
          '/jeecg-boot': ''  //默认所有请求都加了jeecg-boot前缀,需要去掉
        }
99
      },*/
100
      '/jeecg-boot': {
101
        target: 'http://localhost:8080', //请求本地 需要jeecg-boot后台项目
102
103
        ws: false,
        changeOrigin: true
104
      },
105
106
107
108
    }
  },

  lintOnSave: undefined
109
}