vue.config.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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://web.poteviohealth.com/pmgw/',
  67. target: 'https://test.poteviohealth.com/pmgw/',
  68. // target: 'http://localhost:12017/',
  69. changeOrigin: true,
  70. secure: false,
  71. pathRewrite: {
  72. ['^' + process.env.VUE_APP_BASE_API]: ''
  73. }
  74. },
  75. //
  76. [process.env.VUE_APP_ZL_WSS]: {
  77. target: 'https://cdbwss.poteviohealth.com/api/',
  78. // target: 'http://localhost:12017/',
  79. changeOrigin: true,
  80. secure: false,
  81. pathRewrite: {
  82. ['^' + process.env.VUE_APP_ZL_WSS]: ''
  83. }
  84. },
  85. [process.env.VUE_APP_ZL_WSS_ZP]: {
  86. target: 'https://web.poteviohealth.com/prod-api',
  87. // target: 'http://localhost:12017/',
  88. changeOrigin: true,
  89. secure: false,
  90. pathRewrite: {
  91. ['^' + process.env.VUE_APP_ZL_WSS_ZP]: ''
  92. }
  93. },
  94. [process.env.VUE_APP_ZL_WSS_ZP_BT]: {
  95. target: 'https://test.poteviohealth.com/subsidy',
  96. // target: 'http://localhost:12017/',
  97. changeOrigin: true,
  98. secure: false,
  99. pathRewrite: {
  100. ['^' + process.env.VUE_APP_ZL_WSS_ZP_BT]: ''
  101. }
  102. },
  103. [process.env.VUE_APP_ZL_JF]: {
  104. target: 'https://jifen.tjpoteviohealth.com/blade-api',
  105. // target: 'http://localhost:12017/',
  106. changeOrigin: true,
  107. secure: false,
  108. pathRewrite: {
  109. ['^' + process.env.VUE_APP_ZL_JF]: ''
  110. }
  111. },
  112. [process.env.VUE_APP_ZL_HEALTH]: {
  113. // https://web.poteviohealth.com/zhylsia/
  114. target: 'https://web.poteviohealth.com/zhylsia',
  115. // target: 'http://localhost:12017/',
  116. changeOrigin: true,
  117. secure: false,
  118. pathRewrite: {
  119. ['^' + process.env.VUE_APP_ZL_HEALTH]: ''
  120. }
  121. }
  122. }
  123. // after: require('./mock/mock-server.js')
  124. },
  125. configureWebpack: {
  126. // provide the app's title in webpack's name field, so that
  127. // it can be accessed in index.html to inject the correct title.
  128. name: name,
  129. resolve: {
  130. alias: {
  131. '@': resolve('src')
  132. }
  133. }
  134. },
  135. };