0

我是一名初级前端开发人员,我想将其webpack用于我的一个 html 项目,我已经阅读了 webpack 官方文档并进行了配置webpack.common.js, webpack.dev.js, webpack.prod.js

现在,当我<img src="./images/image.jpg" alt="image" />在我的 html 文件中使用并启动webpack-dev-server图像时,图像加载完美,但问题是当我在其他文件(如等)中进行更改时,图像源在 **browser 开发人员工具的网络中index.js, style.scss不起作用webpack-dev-server选项卡 img 类型显示 text/html 但是当我运行生产构建时,图像源工作正常。

我试过file-loader了,但问题webpack-dev-server不是使用通过file-loader它生成的图像,而是使用通过 webpack 的内置加载器生成的图像,而我无法打开的图像是Invalid Image

所以问题出在 webpack 的内置Asset ModuleLoader其他任何东西之间,webpack-dev-server我该如何解决这个问题?

版本

webpack: 5.61.0
webpack-cli: 4.9.1
webpack-dev-server 4.4.0

文件夹结构

在此处输入图像描述

webpack.common.js

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'assets/js/[name].[contenthash].bundle.js',
    assetModuleFilename: 'assets/images/[name].[contenthash].[ext]',
    path: path.resolve(__dirname, 'build'),
    clean: true,
  },
  plugins: [
    new HtmlWebpackPlugin({
      template: './src/index.html',
    }),
    new MiniCssExtractPlugin({
      filename: 'assets/css/[name].[contenthash].css',
    }),
  ],
  module: {
    rules: [
      {
        test: /\.(css|scss|sass)$/i,
        use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader'],
      },
      {
        test: /\.html$/i,
        use: ['html-loader'],
      },
      {
        test: /\.(png|svg|jpg|jpeg|gif)$/i,
        type: 'asset/resource',
      },
    ],
  },
};

webpack.dev.js

const { merge } = require('webpack-merge');
const common = require('./webpack.common');

module.exports = merge(common, {
  mode: 'development',
  devtool: 'source-map',
  devServer: {
    static: './build',
  },
});

webpack.prod.js

const { merge } = require('webpack-merge');
const common = require('./webpack.common');

module.exports = merge(common, {
  mode: 'production',
});
4

0 回答 0