在使用Webpack时解决SCSS文件中的字体路径问题

3

我正在使用webpack和asp.net mvc core项目。我可以捆绑js文件,但是我无法解析我的字体路径。

我有这个scss文件:

$font-path: '../fonts' !global; 

/*fonts*/
/* roboto-300 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 300;
    src: url('#{$font-path}/roboto-v15-latin-300.eot'); /* IE9 Compat Modes */
    src: local('Roboto Light'), local('Roboto-Light'), url('#{$font-path}/roboto-v15-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('#{$font-path}/roboto-v15-latin-300.woff2') format('woff2'), /* Super Modern Browsers */
    url('#{$font-path}/roboto-v15-latin-300.woff') format('woff'), /* Modern Browsers */
    url('#{$font-path}/roboto-v15-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */
    url('#{$font-path}/roboto-v15-latin-300.svg#Roboto') format('svg'); /* Legacy iOS */
}

文件结构:

└── Project
    ├── assets
    │ └── scripts
    │   └── main.ts
    │ └── scss
    │   └── fonts
    │       └── roboto-condensed-v13-latin-700.eot
    │   └── main.scss
    │
    └── webpack.config.js

var path = require('path');
var extractTextPlugin = require("extract-text-webpack-plugin");
var cleanWebpackPlugin = require('clean-webpack-plugin');
var webpack = require('webpack');

module.exports = {
    entry: {
        'role/role': './assets/scripts/role/roleVM.ts',
        main: './assets/scripts/main.ts',
        vendor: ["bootstrap", "popper.js", "jquery"]
    },
    output: {
        filename: 'js/[name].js',
        path: path.resolve(__dirname, 'wwwroot/dist/')
    },
    module: {
        rules: [
            {
                test: /\.tsx?$/,
                loader: 'ts-loader',
                exclude: /node_modules/,
            },
            {
                test: /\.scss$/,
                use: extractTextPlugin.extract({
                    use: [{
                        loader: "css-loader", options: {
                            sourceMap: true
                        }
                    }, {
                        loader: "resolve-url-loader"
                    },
                    {
                        loader: "sass-loader", options: {
                            sourceMap: true
                        },

                    }],
                    fallback: 'style-loader'
                }),
                exclude: /node_modules/
            },
            {
                test: /.(ttf|otf|eot|svg|woff(2)?)(\?[a-z0-9]+)?$/,
                use: [{
                    loader: 'file-loader',
                    options: {
                        name: '[name].[ext]',
                        outputPath: 'fonts/'
                    }
                }]
            }
        ]
    },
    plugins: [
        new cleanWebpackPlugin(['dist'], {
            root: path.resolve(__dirname, 'wwwroot'),
            verbose: true,
            dry: false
        }),
        new webpack.optimize.CommonsChunkPlugin({ name: 'vendor', filename: 'js/vendor.js' }),
        new extractTextPlugin("./css/main.css"),
        new webpack.ProvidePlugin({
            $: 'jquery',
            jQuery: 'jquery',
            'window.jQuery': 'jquery',
            'Popper': 'popper.js'
        })
    ],
    resolve: {
        extensions: [".tsx", ".ts", ".js", '.scss'],
        modules: [
            path.resolve('./'),
            path.resolve('./node_modules'),
        ]
    }
};

当我构建webpack时,我遇到了一个错误:
ERROR in ./node_modules/css-loader?{"sourceMap":true}!./node_modules/resolve-url-loader!./node_modules/sass-loader/lib/loader.js?{"sourceMap":true}!./assets/scss/main.scss 模块未找到:错误:无法解析'../fonts/roboto-condensed-v13-latin-700.eot',位于'C:\ project \ src \ project \ assets \ scss' @ ./node_modules/css-loader?{"sourceMap":true}!./node_modules/resolve-url-loader!./node_modules/sass-loader/lib/loader.js?{"sourceMap":true}!./assets/scss/main.scss 6:215433-215491

1
看起来你应该使用一个点而不是两个点来指定字体路径:$font-path: './fonts' !global; 如果它在 scss 文件夹中的 .scss 文件中,那么 fonts 是相对于此文件夹的子文件夹,而不是相对于其父文件夹。 - GregHNZ
不,我已经尝试过了,没有用。 - capiono
你能显示只有1个点发生的错误吗? - thomasmeadows
1个回答

2

你可以尝试按照以下方式添加这两个选项。

  1. Add entry.devtool option to your webpack config.
  2. ExtractTextPlugin has a publicPath option that can resolve this issue.

    module.exports = {
    entry: {
        'role/role': './assets/scripts/role/roleVM.ts',
        main: './assets/scripts/main.ts',
        vendor: ["bootstrap", "popper.js", "jquery"]
    },
    output: {
        filename: 'js/[name].js',
        path: path.resolve(__dirname, 'wwwroot/dist/')
    },
    devtool:'source-map', //..1. add devtool option to source-map
    module: {
        rules: [
            {
                test: /\.tsx?$/,
                loader: 'ts-loader',
                exclude: /node_modules/,
            },
            {
                test: /\.scss$/,
                use: extractTextPlugin.extract({
                    publicPath:'',
                    //2. add public path to your font folder in the build directory
                    use: [{
                        loader: "css-loader", options: {
                            sourceMap: true
                        }
                    }, {
                        loader: "resolve-url-loader"
                    },
                        {
                            loader: "sass-loader", options: {
                            sourceMap: true
                        },
    
                        }],
                    fallback: 'style-loader'
                }),
                exclude: /node_modules/
            },
            {
                test: /.(ttf|otf|eot|svg|woff(2)?)(\?[a-z0-9]+)?$/,
                use: [{
                    loader: 'file-loader',
                    options: {
                        name: '[name].[ext]',
                        outputPath: 'fonts/'
                    }
                }]
            }
        ]
    },
    plugins: [
        new cleanWebpackPlugin(['dist'], {
            root: path.resolve(__dirname, 'wwwroot'),
            verbose: true,
            dry: false
        }),
        new webpack.optimize.CommonsChunkPlugin({ name: 'vendor', filename: 'js/vendor.js' }),
        new extractTextPlugin("./css/main.css"),
        new webpack.ProvidePlugin({
            $: 'jquery',
            jQuery: 'jquery',
            'window.jQuery': 'jquery',
            'Popper': 'popper.js'
        })
    ],
    resolve: {
        extensions: [".tsx", ".ts", ".js", '.scss'],
        modules: [
            path.resolve('./'),
            path.resolve('./node_modules'),
        ]
    }
    

    };


有没有办法不发出字体文件?忽略来自node_module依赖项的sass文件font-face? - Kwaadpepper

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接