Я пытаюсь использовать некоторые местные веб-шрифты в проекте React. Я включаю их в файл main.scss и загружаю их через webpack. Сборка сборки выполняется правильно, включая стили main.scss. Я вижу, что webpack загружает файлы шрифтов и копирует их в public/fonts /, но мой файл пакета не может найти шрифты.Использование локальных веб-шрифтов с webpack
Как я понимаю, ваш @ font-face src должен быть в зависимости от того, где будет пакет. Я устанавливаю это по тому же пути, что и загружаю шрифты в webpack, './fonts/'. Точная ошибка, что я вижу это:
file:///Users/myusername/Documents/folder1/folder2/folder3/APP/fonts/FoundersGroteskWeb-Regular.woff net::ERR_FILE_NOT_FOUND
Я пытался много разных конфигураций пути, и с помощью опции publicPath в WebPack, но я собираюсь в кругах в этот момент над тем, что кажется, действительно простая ссылочная ошибка.
Структура файла:
APP
├──webpack.config.js
├──src
├──app
├──App.jsx
├──styles
├──main.scss
├──fonts
├──allthefonts.woff
├──public
├──bundle.js
├──fonts
├──allthefonts.woff
App.jsx:
require('./styles/main.scss');
main.scss:
@font-face {
font-family: FoundersGrotesk;
src: url('./fonts/FoundersGroteskWeb-Bold.eot') format('eot'),
url('./fonts/FoundersGroteskWeb-Bold.woff') format('woff'),
url('./fonts/FoundersGroteskWeb-Bold.woff2') format('woff2');
font-weight: bold;
}
@font-face {
font-family: FoundersGrotesk_Cnd;
src: url('./fonts/FoundersGrotXCondWeb-Bold.eot') format('eot'),
url('./fonts/FoundersGrotXCondWeb-Bold.woff') format('woff'),
url('./fonts/FoundersGrotXCondWeb-Bold.woff2') format('woff2');
font-weight: bold;
}
@font-face {
font-family: FoundersGrotesk;
src: url('./fonts/FoundersGroteskWeb-Regular.eot') format('eot'),
url('./fonts/FoundersGroteskWeb-Regular.woff') format('woff'),
url('./fonts/FoundersGroteskWeb-Regular.woff2') format('woff2');
font-weight: normal;
}
webpack.config.js:
'use strict';
const webpack = require('webpack');
const PROD = JSON.parse(process.env.PROD_ENV || '0');
module.exports = {
entry: './src/app/App.jsx',
output: {
path: './src/public/',
filename: PROD ? 'bundle.min.js' : 'bundle.js'
},
module: {
loaders: [
{
test: /\.jsx?$/,
loader: 'babel-loader',
exclude: '/node_modules/',
query: {
presets: ['es2015', 'react', 'stage-1']
}
},
{
test: /\.s?css$/,
loaders: ['style', 'css', 'sass']
},
{
test: /\.(eot|svg|ttf|woff|woff2)$/,
loader: 'file-loader?name=./fonts/[name].[ext]'
}
]
}
};
Не связывайтесь с 'eot' шрифтов - они только для IE8 и ниже, которые Microsoft отказались в январе 2016 года IE9 и прежде всего поддержка WOFF. В другом примечании: не ставьте свои статические активы в свой пакет, обслуживайте их как статический контент. Это экономит как вас, так и ваших пользователей TON полосы пропускания, поскольку статические активы всегда были и остаются по сей день, кэшируются браузером. Если вы их связываете, вы вынуждаете огромные объемы данных, которые не менялись по проводам, обходились вам в счет денег, обходились в счет времени вашего пользователя и приводили к ненужному неудовлетворительному опыту. –
@ Mike'Pomax'Kamermans Возможно, я ошибаюсь, но не файловый загрузчик просто копирует активы из каталога dev в каталог сборки, так что пакет может легко ссылаться на них? Это подход, который я видел в статьях/сообщениях SO при работе с изображениями или шрифтами, я не знаю, как вы использовали бы их в противном случае. – johnjohn
Если мы говорим о https://github.com/webpack/file-loader, то: вид, но он также делает все виды переименования фанк. Если все, что вам нужно, это перемещение активов, использование «cp assets build» вместо этого имеет смысл. Вам JS-код не должен «требовать» статических активов в любом случае O_o –