vue.config.js 3.8 KB

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