vue.config.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. const packageName = require('./package.json').name
  2. const webpack = require('webpack')
  3. const { cdn, getProxyOfDomain, getProxyOfIp } = require('./config')
  4. const external = {
  5. vue: 'Vue',
  6. 'vue-router': 'VueRouter',
  7. vuex: 'Vuex',
  8. axios: 'axios',
  9. lodash: '_',
  10. echarts: 'echarts',
  11. // moment: 'moment',
  12. jquery: '$'
  13. }
  14. module.exports = {
  15. productionSourceMap: false,
  16. outputDir: 'page_big_pc',
  17. publicPath: process.env.VUE_APP_BASE_PUBLIC,
  18. lintOnSave: true,
  19. devServer: {
  20. disableHostCheck: true,
  21. proxy: {
  22. // 反爬虫接口代理
  23. // '/subVipPortrait/winner': {
  24. // target: 'http://192.168.20.178:8800',
  25. // changeOrigin: true,
  26. // logLevel: 'debug'
  27. // },
  28. '^/bigmember': {
  29. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  30. // target: 'http://127.0.0.1:814',
  31. changeOrigin: true,
  32. logLevel: 'debug',
  33. pathRewrite: {
  34. '^/bigmember': '/bigmember'
  35. }
  36. },
  37. '^/jypay': {
  38. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  39. // target: 'http://127.0.0.1:86',
  40. changeOrigin: true,
  41. logLevel: 'debug'
  42. },
  43. '^/publicapply': {
  44. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  45. // target: 'http://127.0.0.1:828',
  46. changeOrigin: true,
  47. logLevel: 'debug'
  48. },
  49. '^/subscribepay': {
  50. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  51. // target: 'http://127.0.0.1:86',
  52. changeOrigin: true,
  53. logLevel: 'debug'
  54. },
  55. '^/salesLeads': {
  56. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  57. // target: 'http://127.0.0.1:8881',
  58. changeOrigin: true,
  59. logLevel: 'debug'
  60. },
  61. '^/privatedata': {
  62. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  63. // target: 'http://127.0.0.1:829',
  64. changeOrigin: true,
  65. logLevel: 'debug'
  66. },
  67. '^/jymessageCenter': {
  68. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  69. // target: 'http://127.0.0.1:829',
  70. changeOrigin: true,
  71. logLevel: 'debug'
  72. },
  73. '^/jyCoupon': {
  74. target: 'https://jybx2-webtest.jydev.jianyu360.com',
  75. changeOrigin: true,
  76. logLevel: 'debug'
  77. },
  78. '^/marketing': {
  79. target: 'http://192.168.3.240:709',
  80. changeOrigin: true,
  81. logLevel: 'debug'
  82. }
  83. },
  84. headers: {
  85. 'Access-Control-Allow-Origin': '*'
  86. },
  87. // proxy: getProxyOfDomain('https://web2-jytest.jydev.jianyu360.com') || getProxyOfIp('http://127.0.0.1')
  88. },
  89. css: {
  90. loaderOptions: {
  91. sass: {
  92. prependData: '@import "@/assets/style/_mixin.scss";@import "@/assets/style/_variables.scss";'
  93. }
  94. }
  95. },
  96. chainWebpack: config => {
  97. // single-spa
  98. if (!process.env.VUE_APP_ALONE) {
  99. if (process.env.NODE_ENV === 'production') {
  100. // 生产环境配置
  101. config.externals(external)
  102. config.plugin('html').tap(args => {
  103. // html中添加cdn
  104. args[0].cdn = cdn
  105. return args
  106. })
  107. config.optimization.minimize(true)
  108. .minimizer('terser')
  109. .tap(args => {
  110. const { terserOptions } = args[0]
  111. terserOptions.compress.drop_console = true
  112. terserOptions.compress.drop_debugger = true
  113. return args
  114. })
  115. } else {
  116. config.devServer.set('inline', false)
  117. config.devServer.set('hot', true)
  118. }
  119. }
  120. // 分析静态资源
  121. if (process.env.use_analyzer) {
  122. config
  123. .plugin('webpack-bundle-analyzer')
  124. .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)
  125. }
  126. },
  127. configureWebpack: {
  128. output: {
  129. library: 'bigMemberSubApp',
  130. libraryTarget: 'umd',
  131. jsonpFunction: `webpackJsonp_${packageName}`
  132. },
  133. plugins: [
  134. new webpack.ProvidePlugin({
  135. jQuery: 'jquery',
  136. $: 'jquery'
  137. })
  138. ]
  139. }
  140. }