我试图通过webpack文件加载器输出所有图像文件,然而webpack忽略了带有PNG扩展名的图像。配置在JPG文件上正常工作。
我的webpack配置:
const path = require('path');
const PATHS = {
src: path.join(__dirname, 'src'),
img: path.join(__dirname, 'src/img'),
styles: path.join(__dirname, 'src/styles'),
build: path.join(__dirname, 'build')
}
module.exports = {
context: PATHS.src,
entry: {
script: ['./scripts/main.js', './styles/main.scss'],
index: './index.html'
},
output: {
path: PATHS.build,
filename: '[name].js'
},
module: {
loaders: [{
test: /\.scss$/,
loaders: ["style", "css", "sass"],
include: PATHS.styles
}, {
test: /\.(png|jpg)$/i,
loader: 'file?name=[path][name].[ext]',
include: PATHS.img
}, {
test: /\.(html)$/,
loader: 'file?name=[path][name].[ext]'
}]
}
};
答案 0 :(得分:2)
PNG文件的问题在于导入PNG图像,两者都是通过html src属性导入的,而JPG图像是通过css中的url属性导入的。因此问题不在图像格式中。
通过将extract-loader和html-loader添加到html加载器来修复。然后,如果我理解正确,Webpack甚至匹配html中的src属性。
Html加载程序配置:
loader: 'file-loader?name=[path][name].[ext]!extract-loader!html-loader'
感谢您指出我的图像导入方法。
答案 1 :(得分:0)
这可能是装载机的问题,您可以尝试url-loader
{ test: /\.(png|jpg|jpeg)$/, loader: 'url-loader?limit=10000' }
答案 2 :(得分:0)
{
test: /\.(png|svg|jpg|gif|jpe?g)$/,
use: [
{
options: {
name: "[name].[ext]",
outputPath: "images/"
},
loader: "file-loader"
}
]
}