vue.config.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. var projectname = process.argv[3];
  2. var glob = require("glob");
  3. var publicPath = ''
  4. console.log(process.env.NODE_ENV)
  5. function getEntry() {
  6. var entries = {};
  7. if (process.env.NODE_ENV == "production") {
  8. entries = {
  9. index: {
  10. // page的入口
  11. entry: "src/views/" + projectname + "/main.js",
  12. // 模板来源
  13. template: "public/index.html",
  14. // 在 dist/index.html 的输出
  15. filename: "index.html",
  16. title: projectname,
  17. chunks: ["chunk-vendors", "chunk-common", "index"]
  18. }
  19. };
  20. publicPath = '/' + projectname + '/'
  21. } else {
  22. var items = glob.sync("./src/views/*/*.js");
  23. for (var i in items) {
  24. var filepath = items[i];
  25. var fileList = filepath.split("/");
  26. var fileName = fileList[fileList.length - 2];
  27. publicPath = '/' + fileName + '/'
  28. entries[fileName] = {
  29. entry: `src/views/${fileName}/main.js`,
  30. // 模板来源
  31. template: `public/index.html`,
  32. // 在 dist/index.html 的输出
  33. filename: `${fileName}.html`,
  34. };
  35. }
  36. }
  37. return entries;
  38. }
  39. const path = require('path')
  40. function resolve(dir) {
  41. return path.join(__dirname, dir)
  42. }
  43. const port = process.env.port || process.env.npm_config_port || 12004 // dev port
  44. const name = 'vue Admin Template' // page title
  45. var pages = getEntry();
  46. console.log(publicPath)
  47. module.exports = {
  48. // publicPath:'/weibao/',
  49. // publicPath: publicPath,
  50. publicPath: process.env.NODE_ENV === 'development' ? publicPath : '././',
  51. productionSourceMap: false, // 生产禁止显示源代码
  52. outputDir: "dist/" + projectname,
  53. pages: pages,
  54. lintOnSave: process.env.NODE_ENV === 'development',
  55. productionSourceMap: false,
  56. devServer: {
  57. port: port,
  58. open: true,
  59. https: false,
  60. overlay: {
  61. warnings: false,
  62. errors: true
  63. },
  64. proxy: {
  65. [process.env.VUE_APP_BASE_API]: {
  66. target: 'https://test.poteviohealth.com/pmgw/',
  67. // target: 'http://localhost:12017/',
  68. changeOrigin: true,
  69. secure: false,
  70. pathRewrite: {
  71. ['^' + process.env.VUE_APP_BASE_API]: ''
  72. }
  73. },
  74. //
  75. [process.env.VUE_APP_ZL_WSS]: {
  76. target: 'https://cdbwss.poteviohealth.com/api/',
  77. // target: 'http://localhost:12017/',
  78. changeOrigin: true,
  79. secure: false,
  80. pathRewrite: {
  81. ['^' + process.env.VUE_APP_ZL_WSS]: ''
  82. }
  83. },
  84. [process.env.VUE_APP_ZL_WSS_ZP]: {
  85. target: 'https://web.poteviohealth.com/prod-api',
  86. // target: 'http://localhost:12017/',
  87. changeOrigin: true,
  88. secure: false,
  89. pathRewrite: {
  90. ['^' + process.env.VUE_APP_ZL_WSS_ZP]: ''
  91. }
  92. },
  93. [process.env.VUE_APP_ZL_WSS_ZP_BT]: {
  94. target: 'https://test.poteviohealth.com/subsidy',
  95. // target: 'http://localhost:12017/',
  96. changeOrigin: true,
  97. secure: false,
  98. pathRewrite: {
  99. ['^' + process.env.VUE_APP_ZL_WSS_ZP_BT]: ''
  100. }
  101. },
  102. [process.env.VUE_APP_ZL_JF]: {
  103. target: 'https://jifen.tjpoteviohealth.com/blade-api',
  104. // target: 'http://localhost:12017/',
  105. changeOrigin: true,
  106. secure: false,
  107. pathRewrite: {
  108. ['^' + process.env.VUE_APP_ZL_JF]: ''
  109. }
  110. },
  111. [process.env.VUE_APP_ZL_HEALTH]: {
  112. // https://web.poteviohealth.com/zhylsia/
  113. target: 'https://web.poteviohealth.com/zhylsia',
  114. // target: 'http://localhost:12017/',
  115. changeOrigin: true,
  116. secure: false,
  117. pathRewrite: {
  118. ['^' + process.env.VUE_APP_ZL_HEALTH]: ''
  119. }
  120. }
  121. }
  122. // after: require('./mock/mock-server.js')
  123. },
  124. configureWebpack: {
  125. // provide the app's title in webpack's name field, so that
  126. // it can be accessed in index.html to inject the correct title.
  127. name: name,
  128. resolve: {
  129. alias: {
  130. '@': resolve('src')
  131. }
  132. }
  133. },
  134. };