vue.config.js 3.9 KB

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