我是一名初级前端开发人员,我想将其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 Module
或Loader
其他任何东西之间,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',
});