使用webpack导入材料设计标志性字体

时间:2018-04-03 16:00:28

标签: javascript material-design webpack-file-loader

使用webpack导入material design iconic fonts时,我已经尝试了几个小时但没有成功。

我的webpack.config.js

...
module: {
    rules: [
        {
            test: /\.css$/,
            use: [
                {loader: "style-loader"},
                {loader: "css-loader"}
            ]
        },
        {
            test: /\.(png|jpg|gif)$/,
            use: [
                {
                    loader: 'file-loader',
                    options: {}
                }
            ]
        },
        {
            test: /\.(svg|eot|woff|ttf|svg|woff2)$/,
            use: [
                {
                    loader: 'file-loader',
                    options: {
                        name: "fonts/[name].[ext]"
                    }
                }
            ]
        }
    ]
...

我的app.js文件

import 'material-design-iconic-font/dist/css/material-design-iconic-font.css';

我的webpack输出控制台

Built at: 2018-4-3 12:48:40
                                  Asset      Size  Chunks             Chunk Names
fonts/Material-Design-Iconic-Font.ttf  96.9 KiB          [emitted]  
fonts/Material-Design-Iconic-Font.woff2  37.5 KiB          [emitted]  
fonts/Material-Design-Iconic-Font.woff  49.1 KiB          [emitted]  
4a37f8008959c75f619bf0a3a4e2d7a2.png  4.86 KiB          [emitted] 

但是在设置

时我没有得到任何图标
<i class='zmdi zmdi-money'></i>

enter image description here

请冷,有人帮帮我吗? 感谢。

1 个答案:

答案 0 :(得分:2)

仔细检查添加的材料设计内联式,我注意到以下声明:

url("fonts/Material-Design-Iconic-Font.woff2") 

这就是为什么它不起作用。导入图标的js文件放在js文件夹(appname / js)上,当执行页面本身时,浏览器试图获取localhost:8080/appname/fonts/Material-Design-Iconic-Font.woff2.根本不存在的内容。 (一旦在js文件夹“appname / js / fonts ...”中创建了字体页面)

要解决此问题,我将webpack.config.js文件更改为

{
    test: /\.(svg|eot|woff|ttf|svg|woff2)$/,
    use: [
        {
            loader: 'file-loader',
            options: {
                name: "[path][name].[ext]"
            }
        }
    ]
}

现在检查结果内联样式,我得

url(node_modules/material-design-iconic-font/dist/fonts/Material-Design-Iconic-Font.woff2)

现在浏览器可以加载它并且图标显示正确。