webpack.config.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. const {resolve} = require('path')
  2. const HtmlWebpackPlugin = require('html-webpack-plugin')
  3. module.exports = {
  4. entry: './src/index.js',
  5. output:{
  6. filename: 'built.js',
  7. path: resolve(__dirname,'build')
  8. },
  9. module:{
  10. rules:[
  11. {
  12. test: /\.less$/,
  13. use: ['style-loader','css-loader','less-loader']
  14. },
  15. {
  16. //处理图片资源
  17. test:/\.(jpeg|png|gif|jpg)$/,
  18. // 需要下载url-loader和file-loader webpack5已弃用,添加type:'javascript/auto'可解决问题。
  19. loader: 'url-loader',
  20. options:{
  21. // 图片大小小于8kb 就会被base64处理
  22. // 减少请求数量 但图片体积会变大
  23. limit: 8 * 1024,
  24. esModule: false // 解决[object%20Module]问题 原因:url-loader默认使用es6模块化解析,html-loader引入图片commonjs
  25. },
  26. type: 'javascript/auto'
  27. },
  28. {
  29. test: /\.html$/,
  30. loader: 'html-loader'
  31. }
  32. ]
  33. },
  34. plugins:[
  35. new HtmlWebpackPlugin({
  36. template: './src/index.html'
  37. })
  38. ],
  39. mode: 'development'
  40. }