webpack.base.conf.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. var path = require('path')
  2. var fs = require('fs')
  3. var utils = require('./utils')
  4. var config = require('../config')
  5. var webpack = require('webpack')
  6. var merge = require('webpack-merge')
  7. var vueLoaderConfig = require('./vue-loader.conf')
  8. var MpvuePlugin = require('webpack-mpvue-asset-plugin')
  9. var glob = require('glob')
  10. var CopyWebpackPlugin = require('copy-webpack-plugin')
  11. var relative = require('relative')
  12. function resolve (dir) {
  13. return path.join(__dirname, '..', dir)
  14. }
  15. function getEntry (rootSrc) {
  16. var map = {};
  17. glob.sync(rootSrc + '/pages/**/main.js')
  18. .forEach(file => {
  19. var key = relative(rootSrc, file).replace('.js', '');
  20. map[key] = file;
  21. })
  22. return map;
  23. }
  24. const appEntry = { app: resolve('./src/main.js') }
  25. const pagesEntry = getEntry(resolve('./src'), 'pages/**/main.js')
  26. const entry = Object.assign({}, appEntry, pagesEntry)
  27. let baseWebpackConfig = {
  28. // 如果要自定义生成的 dist 目录里面的文件路径,
  29. // 可以将 entry 写成 {'toPath': 'fromPath'} 的形式,
  30. // toPath 为相对于 dist 的路径, 例:index/demo,则生成的文件地址为 dist/index/demo.js
  31. entry,
  32. target: require('mpvue-webpack-target'),
  33. output: {
  34. path: config.build.assetsRoot,
  35. jsonpFunction: 'webpackJsonpMpvue',
  36. filename: '[name].js',
  37. publicPath: process.env.NODE_ENV === 'production'
  38. ? config.build.assetsPublicPath
  39. : config.dev.assetsPublicPath
  40. },
  41. resolve: {
  42. extensions: ['.js', '.vue', '.json'],
  43. alias: {
  44. 'vue': 'mpvue',
  45. '@': resolve('src')
  46. },
  47. symlinks: false,
  48. aliasFields: ['mpvue', 'weapp', 'browser'],
  49. mainFields: ['browser', 'module', 'main']
  50. },
  51. module: {
  52. rules: [
  53. {
  54. test: /\.(js|vue)$/,
  55. loader: 'eslint-loader',
  56. enforce: 'pre',
  57. include: [resolve('src'), resolve('test')],
  58. options: {
  59. formatter: require('eslint-friendly-formatter')
  60. }
  61. },
  62. {
  63. test: /\.vue$/,
  64. loader: 'mpvue-loader',
  65. options: vueLoaderConfig
  66. },
  67. {
  68. test: /\.js$/,
  69. include: [resolve('src'), resolve('test')],
  70. use: [
  71. 'babel-loader',
  72. {
  73. loader: 'mpvue-loader',
  74. options: Object.assign({checkMPEntry: true}, vueLoaderConfig)
  75. },
  76. ]
  77. },
  78. {
  79. test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
  80. loader: 'url-loader',
  81. options: {
  82. limit: 10000,
  83. name: utils.assetsPath('img/[name].[ext]')
  84. }
  85. },
  86. {
  87. test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
  88. loader: 'url-loader',
  89. options: {
  90. limit: 10000,
  91. name: utils.assetsPath('media/[name].[ext]')
  92. }
  93. },
  94. {
  95. test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
  96. loader: 'url-loader',
  97. options: {
  98. limit: 10000,
  99. name: utils.assetsPath('fonts/[name].[ext]')
  100. }
  101. }
  102. ]
  103. },
  104. plugins: [
  105. // api 统一桥协议方案
  106. new webpack.DefinePlugin({
  107. 'mpvue': 'global.mpvue',
  108. 'mpvuePlatform': 'global.mpvuePlatform'
  109. }),
  110. new MpvuePlugin(),
  111. new CopyWebpackPlugin([{
  112. from: '**/*.json',
  113. to: ''
  114. }], {
  115. context: 'src/'
  116. }),
  117. new CopyWebpackPlugin([
  118. {
  119. from: path.resolve(__dirname, '../static'),
  120. to: path.resolve(config.build.assetsRoot, './static'),
  121. ignore: ['.*']
  122. }
  123. ])
  124. ]
  125. }
  126. // 针对百度小程序,由于不支持通过 miniprogramRoot 进行自定义构建完的文件的根路径
  127. // 所以需要将项目根路径下面的 project.swan.json 拷贝到构建目录
  128. // 然后百度开发者工具将 dist/swan 作为项目根目录打
  129. const projectConfigMap = {
  130. tt: '../project.config.json',
  131. swan: '../project.swan.json'
  132. }
  133. const PLATFORM = process.env.PLATFORM
  134. if (/^(swan)|(tt)$/.test(PLATFORM)) {
  135. baseWebpackConfig = merge(baseWebpackConfig, {
  136. plugins: [
  137. new CopyWebpackPlugin([{
  138. from: path.resolve(__dirname, projectConfigMap[PLATFORM]),
  139. to: path.resolve(config.build.assetsRoot)
  140. }])
  141. ]
  142. })
  143. }
  144. module.exports = baseWebpackConfig