vue.config.js 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. const path = require("path");
  2. const TerserPlugin = require("terser-webpack-plugin");
  3. const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");
  4. const WorkboxPlugin = require("workbox-webpack-plugin");
  5. const HappyPack = require("happypack");
  6. const webpack = require("webpack");
  7. // const HtmlWebpackPlugin = require("html-webpack-plugin");
  8. function resolve(dir) {
  9. return path.join(__dirname, dir);
  10. }
  11. module.exports = {
  12. chainWebpack(config) {
  13. config.module.rule("svg").exclude.add(resolve("src/icons")).end();
  14. config.module
  15. .rule("icons")
  16. .test(/\.svg$/)
  17. .include.add(resolve("src/icons"))
  18. .end()
  19. .use("svg-sprite-loader")
  20. .loader("svg-sprite-loader")
  21. .options({
  22. symbolId: "icon-[name]",
  23. })
  24. .end();
  25. config.plugin("happypack").use(HappyPack, [
  26. {
  27. loaders: ["babel-loader"],
  28. },
  29. ]);
  30. // config.plugin('dll').use(webpack.DllPlugin, [
  31. // {
  32. // name: '[name]_library',
  33. // path: path.join(__dirname, 'dll', '[name]-manifest.json'),
  34. // },
  35. // ]);
  36. config.plugin("workbox").use(WorkboxPlugin.GenerateSW, [
  37. {
  38. clientsClaim: true,
  39. skipWaiting: true,
  40. },
  41. ]);
  42. },
  43. css: {
  44. loaderOptions: {
  45. postcss: {
  46. postcssOptions: {
  47. plugins: [require("tailwindcss"), require("autoprefixer")],
  48. },
  49. },
  50. sass: {
  51. additionalData: `
  52. @import "@/styles/global.scss";
  53. `,
  54. },
  55. },
  56. },
  57. devServer: {
  58. // contentBase: path.join(__dirname, "public"),
  59. proxy: {
  60. "/api": {
  61. target: process.env.VUE_APP_APIPROXY,
  62. // target: "http://192.168.5.4:16200", // 石月
  63. // target: "http://192.168.50.235:16200", // 内网
  64. // target: "http://192.168.5.15:16200",//陈
  65. // target: "http://192.168.50.235:16600", //演示环境//16600
  66. // target: "http://106.120.102.238:18998/api", //外网演示环境
  67. // target: "http://106.120.102.238:16700", // 外网16700 生产16600
  68. // target: "http://10.96.137.5",
  69. changeOrigin: true,
  70. pathRewrite: {
  71. "^/api": "", // 去掉 /api 前缀
  72. },
  73. },
  74. // 未知量 //振动、激光测距仪
  75. "/WZLapi": {
  76. target: process.env.VUE_APP_WZLAPIPROXY,
  77. // target: "http://192.168.50.241:9001", // WZLapi 目标地址
  78. // target: "http://106.120.102.238:18080/WindTransDev", // WZLapi 外网目标地址
  79. changeOrigin: true,
  80. pathRewrite: {
  81. "^/WZLapi": "", // 去掉 /WZLapi 前缀
  82. },
  83. },
  84. "/ETLapi": {
  85. target: process.env.VUE_APP_ETLAPIPROXY,
  86. // target: "http://192.168.50.241:9001", // WZLapi 目标地址
  87. // target: "http://192.168.5.11:8001", // WZLapi 目标地址
  88. // target: "http://106.120.102.238:18080/ImportDataDev", //导数工具
  89. // target: "http://106.120.102.238:18080/WindTransDev", //WTL外网目标地址
  90. // target: "http://106.120.102.238:18998/transDataWeb", //WTL演示环境
  91. // target: "http://192.168.50.235:8998/transDataWeb", //WTL演示环境
  92. changeOrigin: true,
  93. pathRewrite: {
  94. "^/ETLapi": "", // 去掉 /WZLapi 前缀
  95. },
  96. onProxyReq(proxyReq, req, res) {
  97. console.log("Proxying /sAlgorithm request to:", proxyReq.path); // 打印代理请求路径
  98. },
  99. },
  100. // // 文佳
  101. // "/WJapi": {
  102. // target: process.env.VUE_APP_WJAPIPROXY,
  103. // // target: "http://106.120.102.238:18888",
  104. // changeOrigin: true,
  105. // pathRewrite: {
  106. // "^/WJapi": "",
  107. // },
  108. // },
  109. // 王娇娇健康评估
  110. "/AnalysisMulti": {
  111. target: process.env.VUE_APP_AnalysisMultiAPIPROXY,
  112. // target: "http://106.120.102.238:28999/AnalysisMulti",
  113. changeOrigin: true,
  114. pathRewrite: {
  115. "^/AnalysisMulti": "",
  116. },
  117. },
  118. // 数据转换亮亮
  119. "/transDataWeb": {
  120. target: process.env.VUE_APP_WZLAPIPROXY,
  121. // target: "http://192.168.50.241:9000/trans_data_web",//生产
  122. // target: "http://192.168.50.235/transDataWeb", //测试
  123. // target: "http://106.120.102.238:18998/transDataWeb", //演示外网
  124. // target: "http://192.168.50.235:8999/transDataWeb", //测试
  125. changeOrigin: true,
  126. pathRewrite: {
  127. "^/transDataWeb": "",
  128. },
  129. },
  130. //自定义算法文佳
  131. "/sAlgorithm": {
  132. target: process.env.VUE_APP_sAlgorithmAPIPROXY,
  133. // target: "http://192.168.50.235:8666", // 目标地址
  134. // target: "http://106.120.102.238:58880", //这个代理会走两次代理转发
  135. changeOrigin: true,
  136. pathRewrite: {
  137. "^/sAlgorithm": "",
  138. },
  139. },
  140. //nodejs 数据库数据
  141. "/databaseApi": {
  142. target: process.env.VUE_APP_databaseApiAPIPROXY,
  143. // target: "http://192.168.50.234:3002",
  144. // target: "http://106.120.102.238:58880", //这个代理会走两次代理转发
  145. changeOrigin: true,
  146. pathRewrite: {
  147. "^/databaseApi": "",
  148. },
  149. },
  150. //nodejs 数据库数据
  151. "/downLoadChart": {
  152. target: process.env.VUE_APP_downLoadChartAPIPROXY,
  153. // target: "http://0.0.0.0:3001",
  154. // target: "http://192.168.50.235:8999/downLoadChart", //内网演示
  155. // target: "http://106.120.102.238:28999/downLoadChart", //外网演示
  156. changeOrigin: true,
  157. pathRewrite: {
  158. "^/downLoadChart": "",
  159. },
  160. },
  161. },
  162. },
  163. configureWebpack: {
  164. resolve: {
  165. alias: {
  166. "@": resolve("src"),
  167. },
  168. },
  169. optimization: {
  170. usedExports: true,
  171. splitChunks: {
  172. chunks: "all",
  173. },
  174. minimize: true,
  175. minimizer: [new TerserPlugin(), new CssMinimizerPlugin()],
  176. },
  177. // plugins: [
  178. // new HtmlWebpackPlugin({
  179. // filename: "custom-filename.html", // 自定义输出的 HTML 文件名
  180. // title: "风机运行管理系统", // 设置页面的标题
  181. // // 其他配置...
  182. // }),
  183. // // 其他插件...
  184. // ],
  185. },
  186. pluginOptions: {
  187. "style-resources-loader": {
  188. preProcessor: "sass",
  189. patterns: [],
  190. },
  191. },
  192. configureWebpack: {
  193. devtool: "source-map",
  194. },
  195. };