vue.config.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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. changeOrigin: true, // 只有这个值为true的情况下 才表示开启跨域
  29. pathRewrite: {
  30. '^/api': ''
  31. }
  32. }
  33. }
  34. },
  35. chainWebpack(config) {
  36. config.plugins.delete('prefetch');
  37. if (process.env.NODE_ENV !== 'development') {
  38. // gzip 压缩
  39. config.plugin('compressionPlugin').use(
  40. new CompressionWebpackPlugin({
  41. test: /\.(js|css|html)$/,
  42. threshold: 10240
  43. })
  44. );
  45. }
  46. },
  47. css: {
  48. loaderOptions: {
  49. sass: {
  50. sassOptions: {
  51. outputStyle: 'expanded',
  52. importer: transformElementScss()
  53. }
  54. }
  55. }
  56. }
  57. };