0

我正在现有项目中配置 Webpack,并且避免更改项目结构。在 scss 文件中,我包含以 / 开头的文件(例如 url('/fonts/mem.woff2')),我相信这是我的问题的原因。

样式.scss

@font-face {
    font-family: 'MyFont';
    src: url('/fonts/mem.woff2') format('woff2'),
      url('/fonts/slick.woff') format('woff');
    font-weight: 600;
    font-style: normal;
}

和错误:

错误:在finishWithoutResolve (D:\Programming\Demos\webpack-compact\node_modules\enhanced-resolve\lib) 处无法解析“D:\Programming\Demos\webpack-compact\src”中的“/fonts/mem.woff2” \Resolver.js:293:18) 在 D:\Programming\Demos\webpack-compact\node_modules\enhanced-resolve\lib\Resolver.js:362:15 在 D:\Programming\Demos\webpack-compact\node_modules\增强解析\lib\Resolver.js:410:5 at eval (eval at create (D:\Programming\Demos\webpack-compact\node_modules\enhanced-resolve\node_modules\tapable\lib\Hoo at D:\Programming\ Demos\webpack-compact\node_modules\enhanced-resolve\lib\Resolver.js:410:5 at eval (eval at create (D:\Programming\Demos\webpack-compact\node_modules\enhanced-resolve\node_modules\tapable\lib \Hoo 在 D:\Programming\Demos\webpack-compact\node_modules\enhanced-resolve\lib\Descriptio 在 D:\Programming\Demos\webpack-compact\node_modules\enhanced-resolve\lib\Resolver.j at eval(eval at create (D:\Programming\Demos\webpack-compact\node_modules\enhanced- at D:\Programming\Demos\ webpack-compact\node_modules\enhanced-resolve\lib\Resolver.j

我的 webpack 文件如下所示:

module.exports = env => {
const isDev = env.NODE_ENV == 'dev';

return {
    target: 'web',
    mode: 'development',
    devtool: 'inline-source-map',
    entry: {            
        index: path.resolve(__dirname, "src", "index.js")
    },
    output: {
        filename: '[name].js',
        path: path.resolve(__dirname, 'dist'),            
    },
    devServer: {
        contentBase: path.resolve(__dirname, 'dist'),
        port: '8080',
        host: 'localhost',
        hot: true,
        open: true,
        inline: true
    },
    plugins: [
        new CleanWebpackPlugin(),            
        new HtmlWebpackPlugin({
            title: 'Development',
            template: path.resolve(__dirname, "src", "index.html"),
            filename: 'index.html',
        })
    ],
    module:{
        rules: [               
            {
                test: /\.(woff|woff2|eot|ttf|otf)$/,
                loader: 'file-loader',
                options: {
                    name: '[name].[ext]',
                    outputPath: 'fonts/',
                },
            }
            ...

我知道如果我使用 ./ 将字体路径更改为该路径,它将起作用。我的问题是,是否可以仅更改 webpack 配置而不是转到所有 scss 文件并更改 url('/fonts/mem.woff2') 上的路径?

4

1 回答 1

0

我相信这是可能的webpack.NormalModuleReplacementPlugin

这是你如何做到的:

plugins: [
 //…
 new webpack.NormalModuleReplacementPlugin(
      /^\/fonts\/mem\.woff2/,
      function (resource) {
        resource.request = resource.request.replace(/^\//, './');
      }
    )
]

由于您的示例中有两种字体,您可以应用另一个webpack.NormalModuleReplacementPlugin插件。

于 2021-01-17T11:57:22.833 回答