我正在尝试在我的React项目中使用一些本地web字体。 我将它们包含在我的main.scss文件中,并通过webpack加载它们。 打包正确,包括main.scss样式。 我看到webpack加载字体文件并将其复制到public / fonts /,但是我的bundle文件找不到字体。
据我所知,@font-face src应该与bundle存放在同一路径下。 我将其设置为与我在webpack中加载字体的路径相同,即'./fonts/'。 我看到的确切错误是:
file:///Users/myusername/Documents/folder1/folder2/folder3/APP/fonts/FoundersGroteskWeb-Regular.woff net::ERR_FILE_NOT_FOUND
我已经尝试了许多不同的路径配置,并在webpack中使用publicPath选项,但我现在陷入了一个看起来非常简单的引用错误的死循环中。
文件结构:
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及以下版本,这些版本已在2016年1月被微软放弃。 IE9及以上版本都支持WOFF。另外一点:不要将静态资源放入您的程序包中,应该作为静态内容提供服务。这样可以节省您和用户大量的带宽,因为静态资源一直以来都可以并且现在仍然可以被浏览器缓存。如果您将它们捆绑在一起,就会强制传输未经更改的大量数据,这会浪费您的金钱、用户的时间,并导致不必要的差劲体验。 - Mike 'Pomax' Kamermanscp assets build
更加合理。你的 JS 代码不应该需要require
静态资源。O_o - Mike 'Pomax' Kamermans