webpack.prod.config.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. const path = require('path');
  2. //const webpack = require('webpack');
  3. const merge = require('webpack-merge');
  4. const baseWpConfig = require('./webpack.base.config');
  5. const TerserPlugin = require('terser-webpack-plugin');
  6. const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
  7. const MiniCssExtractPlugin = require('mini-css-extract-plugin');
  8. const CleanWebpackPlugin = require('clean-webpack-plugin');
  9. const HtmlWebpackPlugin = require('html-webpack-plugin');
  10. const CopyWebpackPlugin = require('copy-webpack-plugin');
  11. const publicDir = path.resolve(__dirname, '../dist/tmp/public');
  12. const clientDir = path.resolve(__dirname, '../client');
  13. module.exports = merge(baseWpConfig, {
  14. mode: 'production',
  15. output: {
  16. path: `${publicDir}/app_new`,
  17. filename: 'bundle.[contenthash].js'
  18. },
  19. module: {
  20. rules: [
  21. {
  22. test: /\.css$/,
  23. use: [
  24. MiniCssExtractPlugin.loader,
  25. 'css-loader'
  26. ]
  27. }
  28. ]
  29. },
  30. optimization: {
  31. minimizer: [
  32. new TerserPlugin(),
  33. new OptimizeCSSAssetsPlugin()
  34. ]
  35. },
  36. plugins: [
  37. new CleanWebpackPlugin([publicDir], {root: path.resolve(__dirname, '..')}),
  38. new MiniCssExtractPlugin({
  39. filename: "[name].[contenthash].css"
  40. }),
  41. new HtmlWebpackPlugin({
  42. template: `${clientDir}/index.html.template`,
  43. filename: `${publicDir}/index.html`
  44. }),
  45. new CopyWebpackPlugin([{from: `${clientDir}/assets/*`, to: `${publicDir}/`, flatten: true}])
  46. ]
  47. });