在webpack中加载.otf字体文件的正确方法是什么?

7

在使用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'
    })
  ]
};

1
你能分享一下你的 webpack 配置文件中完整的 module.loaders 吗? - Bulkan
@Bulkan 我已经在最后修改了我的问题,包含了完整的 webpack.config.js。这能帮到你吗? - abgregs
你确定已经安装了url-loader和file-loader吗? - Mudiaga Ejenavi
@MudiagaEjenavi 感谢您的提问。我已经检查了,file-loader和url-loader都已安装。您有没有关于如何在我的webpack.config.js中指定这两个加载器的建议?或者可能是其他原因导致我收到错误信息? - abgregs
2个回答

12

我添加了

  {    
    test: /\.(woff|woff2|eot|ttf|otf)$/,
    loader: "file-loader"
  }

对于我的webpack.config.js文件,我认为我需要显式地将类型链接到file-loader。 我正在使用默认的VS2017 Angular项目。


0
在我的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助手将自动将样式注入到您的css文件中。您可以将styled-components内容移动到单独的.js文件中,然后进行导入。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接