Ошибка Webpack при компиляции sass

У меня есть компонент sass, как так:

@font-face {
  font-family: 'icomoon';
  src:  url('../fonts/icomoon.eot');
  src:  url('../fonts/icomoon.eot') format('embedded-opentype'),
    url('../fonts/icomoon.ttf') format('truetype'),
    url('../fonts/icomoon.woff') format('woff'),
    url('../fonts/icomoon.svg') format('svg');
  font-weight: normal;
  font-style: normal;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-close2:before {
  content: "e66d";
}
.icon-checkmark2:before {
  content: "ea11";
}

и webpack конфигурации, как это:

var webpack = require('webpack');
var path = require('path');

var BUILD_DIR = path.resolve(__dirname, 'public/js/');
var APP_DIR = path.resolve(__dirname, 'jsx');

var config = {
    entry: APP_DIR + '/index.jsx',
    output: {
        path: BUILD_DIR,
        filename: 'app.js'
    },
    module : {
        loaders : [
            {
                test : /.jsx?/,
                include : APP_DIR,
                loader : 'babel'
            },
            {
                test: /.scss$/,
                loaders: ['style', 'css', 'sass']
            }
        ]
    }
};

module.exports = config;

как только у меня был компонент sass выше, я получаю следующую ошибку:

Ошибка в ./ public / шрифты / icomoon.ошибка синтаксического анализа модуля ttf:
/ Пользователи / alessandro.santese / Desktop/Alessandro/AIA/проекты/accenture-tshirtbuilder/tshirtbuilder/public/шрифты / icomoon.ТЦФ
Непредвиденный характер » (1: 0) Вам может понадобиться соответствующий загрузчик для
обработайте этот тип файла.

и многие другие, как это для других шрифтов

1 ответ

  1. В конфигурации webpack отсутствует загрузчик для файла ttf. Я думаю, что вы должны использовать загрузчик url в вашем случае.
    Добавить в загрузчик

    {
      test: /\.(eot|woff|woff2|ttf|svg|png|jpg)$/,
      loader: 'url-loader?limit=30000&name=[name]-[hash].[ext]'
    }
    

    Вам нужно будет установить его: npm install url-loader --save-dev