在使用webpack时,加载.otf字体文件的适当方式是什么?根据我看到的许多示例,我尝试在我的webpack.config.js
中包含规则,但没有成功。
{ test: /\.(eot|svg|ttf|otf|woff)$/, use: 'file-loader' }
//or
{ test: /\.(eot|svg|ttf|otf|woff)$/, use: 'url-loader' }
//or
{ test: /\.(ttf|eot|svg|woff(2)?)(\?[a-z0-9=&.]+)?$/, use: 'file-loader' }
//...etc
我在我的webpack.config.js
中设置了以下内容,用于处理其他文件类型,并且这些设置已经成功运行:
module.exports = {
//...
module: {
rules: [
{ test: /\.(js)$/, use: 'babel-loader' },
{ test: /\.css$/, use: [ 'style-loader', 'css-loader' ]},
{ test: /\.(jpe?g|png|gif|svg|xml)$/i, use: 'file-loader'}
]
},
//...
}
尽管我尝试添加另一个 .otf 文件的规则/情况,但总是出现以下错误:
模块解析失败:.../fonts/[我的字体名称].otf 意外字符' ' (1:4) 您可能需要适当的加载器来处理此文件类型。
我将 .otf 文件添加到根目录下的“fonts”文件夹中,并在我的 index.css 中加入了以下内容:
@font-face {
font-family: 'name-of-my-font';
src: url('fonts/name-of-my-font.otf'),
format('opentype');
}
有没有人遇到过类似的问题并找到了解决方法?
根据评论要求更多的webpack.config.js
文件内容,在这里提供了我全部的webpack.config.js
文件:
var path = require('path');
var HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
entry: './app/index.js',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'index_bundle.js',
publicPath: '/'
},
module: {
rules: [
{ test: /\.(js)$/, use: 'babel-loader' },
{ test: /\.css$/, use: [ 'style-loader', 'css-loader' ]},
{ test: /\.(jpe?g|png|gif|svg|xml)$/i, use: 'file-loader' }
]
},
devServer: {
historyApiFallback: true,
},
plugins: [
new HtmlWebpackPlugin({
template: 'app/index.html'
})
]
};
module.loaders
吗? - Bulkanwebpack.config.js
。这能帮到你吗? - abgregs