在webpack中加载.otf字体文件的正确方法是什么?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在webpack中加载.otf字体文件的正确方法是什么?相关的知识,希望对你有一定的参考价值。
使用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 / [name-of-my-font] .otf意外字符''(1:4)您可能需要一个合适的加载程序来处理此文件类型。
我已经在我的根目录的fonts
文件夹中添加了.otf文件,在我的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'
})
]
};
答案
我补充道
{
test: /.(woff|woff2|eot|ttf|otf)$/,
loader: "file-loader"
}
到我的webpack.config.js。我想我需要明确地将类型链接到文件加载器。我使用的是默认的VS2017 Angular项目。
另一答案
在我的webpack.config.js中我有:
{
test: /.(woff|woff2|eot|ttf|otf)$/,
use: "file-loader"
}
然后在我的index.js文件中,我有:
import React from 'react';
import ReactDOM from 'react-dom';
import { injectGlobal } from 'styled-components';
import avenir from '../font/AvenirLTStd-Light.otf';
injectGlobal`
@font-face {
font-family: 'Avenir';
src: url(${avenir}) format('opentype');
font-weight: normal;
font-style: normal;
}
* {
font-family: 'Avenir', sans-serif;
}
`;
import App from './components/App';
ReactDOM.render(
<App />
, document.querySelector('#root')
);
使用styled-components库中的injectGlobal helper会自动将样式注入到css文件中。你可以将样式组件的东西移动到一个单独的.js文件然后导入它。
以上是关于在webpack中加载.otf字体文件的正确方法是什么?的主要内容,如果未能解决你的问题,请参考以下文章