webpack.prod.config.js 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. const fs = require('fs-extra');
  2. const path = require('path');
  3. //const webpack = require('webpack');
  4. const { merge } = require('webpack-merge');
  5. const baseWpConfig = require('./webpack.base.config');
  6. const TerserPlugin = require('terser-webpack-plugin');
  7. const CssMinimizerWebpackPlugin = require('css-minimizer-webpack-plugin');
  8. const MiniCssExtractPlugin = require('mini-css-extract-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. fs.emptyDirSync(publicDir);
  14. module.exports = merge(baseWpConfig, {
  15. mode: 'production',
  16. output: {
  17. path: `${publicDir}/app`,
  18. filename: 'bundle.[contenthash].js',
  19. clean: true
  20. },
  21. module: {
  22. rules: [
  23. {
  24. test: /\.css$/,
  25. use: [
  26. MiniCssExtractPlugin.loader,
  27. 'css-loader'
  28. ]
  29. }
  30. ]
  31. },
  32. optimization: {
  33. minimizer: [
  34. new TerserPlugin({
  35. parallel: true,
  36. terserOptions: {
  37. format: {
  38. comments: false,
  39. },
  40. },
  41. }),
  42. new CssMinimizerWebpackPlugin()
  43. ]
  44. },
  45. plugins: [
  46. new MiniCssExtractPlugin({
  47. filename: "[name].[contenthash].css"
  48. }),
  49. new HtmlWebpackPlugin({
  50. template: `${clientDir}/index.html.template`,
  51. filename: `${publicDir}/index.html`
  52. }),
  53. new CopyWebpackPlugin({patterns:
  54. [{context: `${clientDir}/assets`, from: `${clientDir}/assets/*`, to: `${publicDir}/` }]
  55. }),
  56. ]
  57. });