vue.config.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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://192.168.3.240: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://192.168.3.240:86',
  40. changeOrigin: true,
  41. logLevel: 'debug'
  42. },
  43. '^/publicapply': {
  44. // target: 'https://jybx2-webtest.jydev.jianyu360.com',
  45. target: 'http://192.168.3.240:828',
  46. changeOrigin: true,
  47. logLevel: 'debug'
  48. },
  49. '^/subscribepay': {
  50. // target: 'https://jybx2-webtest.jydev.jianyu360.com',
  51. target: 'http://192.168.3.240: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. target: 'http://192.168.3.240:827',
  76. changeOrigin: true,
  77. logLevel: 'debug'
  78. },
  79. '^/marketing': {
  80. // target: 'https://jybx2-webtest.jydev.jianyu360.com',
  81. target: 'http://192.168.3.240:8077',
  82. changeOrigin: true,
  83. logLevel: 'debug',
  84. // pathRewrite: {
  85. // '': '/jyapi'
  86. // }
  87. }
  88. },
  89. headers: {
  90. 'Access-Control-Allow-Origin': '*'
  91. },
  92. // proxy: getProxyOfDomain('https://web2-jytest.jydev.jianyu360.com') || getProxyOfIp('http://127.0.0.1')
  93. },
  94. css: {
  95. loaderOptions: {
  96. sass: {
  97. prependData: '@import "@/assets/style/_mixin.scss";@import "@/assets/style/_variables.scss";'
  98. }
  99. }
  100. },
  101. chainWebpack: config => {
  102. // single-spa
  103. if (!process.env.VUE_APP_ALONE) {
  104. if (process.env.NODE_ENV === 'production') {
  105. // 生产环境配置
  106. config.externals(external)
  107. config.plugin('html').tap(args => {
  108. // html中添加cdn
  109. args[0].cdn = cdn
  110. return args
  111. })
  112. config.optimization.minimize(true)
  113. .minimizer('terser')
  114. .tap(args => {
  115. const { terserOptions } = args[0]
  116. terserOptions.compress.drop_console = true
  117. terserOptions.compress.drop_debugger = true
  118. return args
  119. })
  120. } else {
  121. config.devServer.set('inline', false)
  122. config.devServer.set('hot', true)
  123. }
  124. }
  125. // 分析静态资源
  126. if (process.env.use_analyzer) {
  127. config
  128. .plugin('webpack-bundle-analyzer')
  129. .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)
  130. }
  131. },
  132. configureWebpack: {
  133. output: {
  134. library: 'bigMemberSubApp',
  135. libraryTarget: 'umd',
  136. jsonpFunction: `webpackJsonp_${packageName}`
  137. },
  138. plugins: [
  139. new webpack.ProvidePlugin({
  140. jQuery: 'jquery',
  141. $: 'jquery'
  142. })
  143. ]
  144. }
  145. }