vue.config.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. const CompressionWebpackPlugin = require('compression-webpack-plugin');
  2. const { transformElementScss } = require('ele-admin/lib/utils/dynamic-theme');
  3. const path = require('path');
  4. function resolve(dir) {
  5. return path.join(__dirname, dir);
  6. }
  7. module.exports = {
  8. lintOnSave: false,
  9. productionSourceMap: false,
  10. configureWebpack: {
  11. performance: {
  12. maxAssetSize: 2000000,
  13. maxEntrypointSize: 2000000
  14. }
  15. },
  16. devServer: {
  17. // 代理跨域的配置
  18. port: 9999,
  19. headers: {
  20. // 允许跨域访问子应用页面
  21. 'Access-Control-Allow-Origin': '*'
  22. },
  23. proxy: {
  24. // 当我们的本地的请求 有/api的时候,就会代理我们的请求地址向另外一个服务器发出请求
  25. '/api': {
  26. // target: 'http://124.71.68.31:50001',
  27. // target: 'http://192.168.1.105:18086',
  28. // target: 'http://192.168.1.251:18186',
  29. target: 'http://192.168.1.251:18186',
  30. changeOrigin: true, // 只有这个值为true的情况下 才表示开启跨域
  31. pathRewrite: {
  32. '^/api': ''
  33. }
  34. }
  35. }
  36. },
  37. chainWebpack(config) {
  38. config.plugins.delete('prefetch');
  39. if (process.env.NODE_ENV !== 'development') {
  40. // gzip 压缩
  41. config.plugin('compressionPlugin').use(
  42. new CompressionWebpackPlugin({
  43. test: /\.(js|css|html)$/,
  44. threshold: 10240
  45. })
  46. );
  47. }
  48. },
  49. css: {
  50. loaderOptions: {
  51. sass: {
  52. sassOptions: {
  53. outputStyle: 'expanded',
  54. importer: transformElementScss()
  55. }
  56. }
  57. }
  58. }
  59. };