vue.config.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. const path = require('path')
  2. function resolve(dir) {
  3. return path.join(__dirname, dir)
  4. }
  5. /**
  6. * cdn 引入资源
  7. */
  8. const cdn = {
  9. externals: {
  10. vue: 'Vue',
  11. 'vue-router': 'VueRouter',
  12. vuex: 'Vuex',
  13. axios: 'axios',
  14. 'element-ui': 'ELEMENT',
  15. 'echarts': 'echarts',
  16. winseaview: 'winseaview',
  17. // 'base-template-lib': 'base-template-lib',
  18. // 'ali-oss': 'ali-oss',
  19. // 'lodash': 'lodash'
  20. },
  21. js: {
  22. dev: [
  23. "//cdn.bootcdn.net/ajax/libs/sockjs-client/1.5.0/sockjs.min.js",
  24. "//cdn.bootcdn.net/ajax/libs/stomp.js/2.3.3/stomp.min.js",
  25. "//cdn.bootcdn.net/ajax/libs/Sortable/1.9.0/Sortable.min.js"
  26. ],
  27. ship: [
  28. `./static/libs/sock.min.js`,
  29. `./static/libs/stomp.min.js`,
  30. `./cdn/Sortable/1.9.0/Sortable.min.js`,
  31. `./cdn/vue/2.6.10/vue.min.js`,
  32. `./cdn/vuex/3.1.1/vuex.min.js`,
  33. `./cdn/vue-router/3.0.1/vue-router.min.js`,
  34. `./cdn/axios/1.0.0/axios.min.js`,
  35. `./cdn/element-ui/2.12.0/index.js`,
  36. `./cdn/echarts/echarts.min.js`,
  37. `./cdn/lodash/4.17.20/lodash.min.js`,
  38. // `${process.env.BASE_URL}cdn/base-template-lib/base-template-lib.umd.min.js`,
  39. // `${process.env.BASE_URL}cdn/winseaview/winseaview.min.js`
  40. ],
  41. product: [
  42. "//cdn.bootcdn.net/ajax/libs/sockjs-client/1.5.0/sockjs.min.js",
  43. "//cdn.bootcdn.net/ajax/libs/stomp.js/2.3.3/stomp.min.js",
  44. "//cdn.bootcdn.net/ajax/libs/Sortable/1.9.0/Sortable.min.js",
  45. "//cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.min.js",
  46. "//cdn.bootcdn.net/ajax/libs/vuex/3.1.1/vuex.min.js",
  47. "//cdn.bootcdn.net/ajax/libs/vue-router/3.0.1/vue-router.min.js",
  48. "//cdn.bootcdn.net/ajax/libs/axios/0.21.0/axios.min.js",
  49. "//cdn.bootcdn.net/ajax/libs/element-ui/2.12.0/index.js",
  50. "//cdn.bootcdn.net/ajax/libs/echarts/4.8.0/echarts.min.js",
  51. // "//cdn.bootcdn.net/ajax/libs/lodash.js/4.17.20/lodash.min.js",
  52. // "//cdn.bootcdn.net/ajax/libs/ali-oss/6.11.2/aliyun-oss-sdk.min.js",
  53. // `/cdn/base-template-lib/base-template-lib.umd.min.js`,
  54. `/cdn/winseaview/winseaview.min.js`
  55. ]
  56. },
  57. css: {
  58. dev: [
  59. "/cdn/element-ui/2.13.2/theme-chalk/index.css",
  60. "//at.alicdn.com/t/font_1833052_qk0ltgbl23s.css"
  61. ],
  62. ship: [
  63. "/cdn/element-ui/2.13.2/theme-chalk/index.css",
  64. `./static/iconfont/iconfont.css`,
  65. `./static/logo/iconfont.css`
  66. ],
  67. product: [
  68. `/cdn/winseaview/index.css`,
  69. "/cdn/element-ui/2.13.2/theme-chalk/index.css",
  70. "//at.alicdn.com/t/font_1833052_qk0ltgbl23s.css",
  71. ]
  72. }
  73. }
  74. const port = 9527 // dev port
  75. const ignoreFile = ['production']
  76. module.exports = {
  77. assetsDir: 'static',
  78. lintOnSave: true,
  79. publicPath: process.env.VUE_APP_PACKAGE_ENV === 'ship' ? '/' : './',
  80. productionSourceMap: false, //去掉 .map 文件
  81. // runtimeCompiler: true,
  82. // cssSourceMap: true,
  83. devServer: {
  84. port: port,
  85. disableHostCheck: true,
  86. open: false,
  87. overlay: {
  88. warnings: false,
  89. errors: true
  90. },
  91. proxy: {
  92. '/pb/bijiadan': {
  93. // target: 'http://127.0.0.1:4523/mock/349485',//目标地址
  94. target: 'http://192.168.24.5:8045',//目标地址
  95. // target: 'http://192.168.24.24:8089',//目标地址
  96. changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
  97. pathRewrite: {
  98. '^/pb/bijiadan': '/'
  99. }, //这里重写路径
  100. logLevel: 'debug',
  101. },
  102. '/pb/hs': {
  103. // target: 'http://127.0.0.1:4523/mock/349485',//目标地址
  104. target: 'http://192.168.24.24:8045',// 刘宪春本地目标地址
  105. // target: 'http://192.168.22.6:8020',//目标地址
  106. // target: 'http://192.168.24.24:8089',//目标地址
  107. changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
  108. pathRewrite: {
  109. '^/pb/hs': '/'
  110. }, //这里重写路径
  111. logLevel: 'debug',
  112. },
  113. '/pb/mock': {
  114. target: 'http://127.0.0.1:4523/mock/349485',//目标地址
  115. changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
  116. pathRewrite: {
  117. '^/pb/mock': '/'
  118. }, //这里重写路径
  119. logLevel: 'debug',
  120. },
  121. '/pb/apiFinance': {
  122. target: 'http://192.168.24.5:8098',//目标地址
  123. changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
  124. pathRewrite: {
  125. '^/pb/apiFinance': '/'
  126. }, //这里重写路径
  127. logLevel: 'debug',
  128. },
  129. '/pb/api': {
  130. // target: 'http://127.0.0.1:4523/mock/349485',//目标地址
  131. target: 'http://192.168.24.5:8098',//目标地址
  132. // target: 'http://192.168.24.24:8089',//目标地址
  133. changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
  134. pathRewrite: {
  135. '^/pb/api': '/'
  136. }, //这里重写路径
  137. logLevel: 'debug',
  138. },
  139. '/pb': {
  140. // target: 'https://product-server.winsea.com/', //目标地址
  141. // target: 'http://standard-dev.winsea.com/', //目标地址
  142. // target: 'http://localhost:8090/',
  143. // target: 'http://192.168.1.121:8090/',
  144. target: 'http://192.168.1.117:9100/',
  145. // target: 'http://192.168.1.116:8090/',
  146. // target: 'http://192.168.1.119:8090/',
  147. // target: 'http://192.168.24.5:8098',//目标地址
  148. // target: 'http://product-server.winsea.com/',
  149. // target: 'http://192.168.24.5:8098',//目标地址
  150. changeOrigin: true, //开启代理:在本地会创建一个虚拟服务端,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据的交互就不会有跨域问题
  151. pathRewrite: { '^/pb': '/' }, //这里重写路径
  152. secure: false,
  153. logLevel: 'debug',
  154. // headers: {
  155. // Referer: 'http://192.168.23.9:9527/',//'https://product-server.winsea.com/'
  156. // }
  157. },
  158. }
  159. },
  160. configureWebpack: (config) => {
  161. // provide the app's title in webpack's name field, so that
  162. // it can be accessed in index.html to inject the correct title.
  163. // if (debug) { // 开发环境配置
  164. // config.devtool = 'source-map'
  165. // }
  166. //直接修改配置
  167. config.resolve.alias['@'] = resolve('src')
  168. config.resolve.alias['@/assets'] = resolve('src/assets')
  169. if (ignoreFile.includes(process.env.NODE_ENV)) {
  170. config.optimization.minimizer[0].options.terserOptions.compress.warnings = false
  171. config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
  172. config.optimization.minimizer[0].options.terserOptions.compress.drop_debugger = true
  173. config.optimization.minimizer[0].options.terserOptions.compress.pure_funcs = ['console.log', 'console.info']
  174. }
  175. },
  176. chainWebpack(config) {
  177. config.plugins.delete('preload')
  178. config.plugins.delete('prefetch')
  179. config.output.chunkFilename('static/js/[name].[chunkhash].js').end()
  180. const entry = config.entry('app')
  181. entry.add('babel-polyfill').end()
  182. entry.add('classlist-polyfill').end()
  183. /* 添加分析工具 */
  184. if (process.env.NODE_ENV === 'production') {
  185. // config
  186. // .plugin('webpack-bundle-analyzer')
  187. // .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)
  188. // .end()
  189. }
  190. // entry.add('@/mock').end()
  191. //忽略的打包文件
  192. if (ignoreFile.includes(process.env.NODE_ENV)) {
  193. //忽略的打包文件
  194. config.externals(cdn.externals)
  195. //开启Gzip压缩
  196. config
  197. .plugin('gzip-plugin')
  198. .use('compression-webpack-plugin', [{
  199. filename: '[path].gz[query]',
  200. algorithm: 'gzip',
  201. test: /\.js$|\.html$|\.json$|\.css$|\.ttf$/,
  202. threshold: 10240, // 对超过10k的数据压缩
  203. minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理
  204. deleteOriginalAssets: false // 删除原文件
  205. }])
  206. .end()
  207. }
  208. config.plugin('html')
  209. .tap(args => {
  210. args[0].cdn = cdn
  211. return args
  212. })
  213. config.module.rule('images')
  214. .use('url-loader')
  215. .loader('url-loader')
  216. .tap(options => Object.assign(options, {
  217. esModule: false
  218. }))
  219. // set preserveWhitespace
  220. config.module
  221. .rule('vue')
  222. .use('vue-loader')
  223. .loader('vue-loader')
  224. .tap(options => {
  225. options.compilerOptions.preserveWhitespace = true
  226. return options
  227. })
  228. .end()
  229. config.when(process.env.NODE_ENV === 'development', config =>
  230. config.devtool('cheap-source-map')
  231. // config.devtool('source-map') // 源码-慢
  232. )
  233. config.when(process.env.NODE_ENV !== 'development', config => {
  234. // // 压缩代码
  235. config.optimization.minimize(true)
  236. config.optimization.splitChunks({
  237. chunks: 'all',
  238. cacheGroups: {
  239. libs: {
  240. name: 'chunk-libs',
  241. test: /[\\/]node_modules[\\/]/,
  242. priority: 10,
  243. chunks: 'initial' //只打包初始时依赖的第三方
  244. },
  245. // elementUI: {
  246. // name: "chunk-elementUI", // 单独将 elementUI 拆包
  247. // test: /[\\/]node_modules[\\/]element-ui[\\/]/,
  248. // chunks: "all",
  249. // priority: 3,
  250. // reuseExistingChunk: true,
  251. // enforce: true
  252. // },
  253. commons: {
  254. name: 'chunk-commons',
  255. test: resolve('src/components'), // 可自定义拓展你的规则
  256. minChunks: 3, // 最小共用次数
  257. priority: 5,
  258. reuseExistingChunk: true,
  259. minSize: 0,
  260. priority: 1,
  261. enforce: true
  262. }
  263. }
  264. })
  265. config.optimization.runtimeChunk('single')
  266. })
  267. }
  268. }