pol*_*llx 5 javascript reactjs webpack storybook
我是 webpack 的新手,我正在尝试按照本教程https://medium.com/@mushti_dev/hey-e6faa20b910a将自定义字体加载到 stroybook v4 中
工作区结构如下所示(create-react-app + Storybook)
my-project/
.storybook
config.js
preview-hrad.html
webpack.config.js
fonts
MyCustomFont.woff
src
components
Title.js
containers
styles
MyCustomFont.woff
index.js
stories
Run Code Online (Sandbox Code Playgroud)
从src中的styles文件夹加载字体时,配置如下:
webpack.config.js
my-project/
.storybook
config.js
preview-hrad.html
webpack.config.js
fonts
MyCustomFont.woff
src
components
Title.js
containers
styles
MyCustomFont.woff
index.js
stories
Run Code Online (Sandbox Code Playgroud)
预览-head.html
const path = require('path');
module.exports = async ({ config }) => {
// fonts
config.module.rules.push({
test: /\.(png|woff|woff2|eot|ttf|svg)$/,
use: [
{
loader: 'file-loader',
query: {
name: '[name].[ext]',
}
}
],
include: path.resolve(__dirname, '../')
});
return config;
};
Run Code Online (Sandbox Code Playgroud)
标题.js
<style type="text/css">
@font-face {
font-family: 'MyCustomFont';
src: url('styles/MyCustomFont.woff') format('woff');
font-weight: normal;
font-style: normal;
}
</style>
Run Code Online (Sandbox Code Playgroud)
我的问题是如何从字体文件夹加载 MyCustomFont.woff ?
我尝试更新 webpack 配置和 name: 'fonts/[name].[ext]',css 样式src: url('fonts/MyCustomFont.woff') format('woff');,但我很难匹配正确的字体路径。
我刚刚遇到这个问题storybook v6.1,然后意识到实际上有两个字体区域需要设置:
preview-head.html)manager-head.html)我做了什么:
preview-head.html命名为manager-head.html@font-face相对于 npm 脚本中指定的静态文件夹路径-smain.js我的文件夹结构
|- .storybook/
|- ...
|- preview-head.html
|- manager-head.html
|- src/
|- ...
|- fonts/
|- font-name.otf
Run Code Online (Sandbox Code Playgroud)
preview-head.html和manager-head.html
<style type="text/css">
@font-face {
font-family: 'font-name';
src: url('fonts/font-name.otf') format('opentype');
...
}
</style>
Run Code Online (Sandbox Code Playgroud)
package.json
{
...
"scripts": {
...
"storybook": "start-storybook ... -s ./src",
"build-storybook": "build-storybook -s ./src"
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9238 次 |
| 最近记录: |