Webpack file-loader与url-loader深度指南

 更新时间:2026年03月18日 09:09:21   作者:图的AI码课日记  
本文主要介绍了Webpack file-loader与url-loader深度指南,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、静态资源处理的演进

webpack 4 及之前

需要 file-loader 和 url-loader 处理图片、字体等资源。

module.exports = {
  module: {
    rules: [
      {
        test: /\.(png|jpg|gif)$/,
        use: ['file-loader']
      }
    ]
  }
};

webpack 5

内置 Asset Modules,无需额外 loader。

module.exports = {
  module: {
    rules: [
      {
        test: /\.(png|jpg|gif)$/,
        type: 'asset/resource'
      }
    ]
  }
};

二、file-loader

将文件复制到输出目录,返回文件路径。

基础用法

{
  test: /\.(png|jpg|gif)$/,
  use: {
    loader: 'file-loader',
    options: {
      name: '[name].[hash:8].[ext]',
      outputPath: 'images/'
    }
  }
}

配置选项

{
  loader: 'file-loader',
  options: {
    // 文件名模板
    name: '[path][name].[ext]',
    
    // 输出目录
    outputPath: 'assets/',
    
    // 公共路径
    publicPath: '/static/',
    
    // 自定义文件名
    name(file) {
      if (process.env.NODE_ENV === 'development') {
        return '[path][name].[ext]';
      }
      return '[contenthash].[ext]';
    }
  }
}

三、url-loader

小文件转 base64,大文件用 file-loader。

基础用法

{
  test: /\.(png|jpg|gif)$/,
  use: {
    loader: 'url-loader',
    options: {
      limit: 8192,  // 8KB 以下转 base64
      fallback: 'file-loader'
    }
  }
}

优势

  • 减少 HTTP 请求
  • 小图标直接内联

劣势

  • 增加 JS/CSS 体积
  • 无法利用浏览器缓存

四、webpack 5 Asset Modules

四种类型

module.exports = {
  module: {
    rules: [
      // asset/resource:替代 file-loader
      {
        test: /\.(png|jpg|gif)$/,
        type: 'asset/resource'
      },
      
      // asset/inline:替代 url-loader(强制 base64)
      {
        test: /\.svg$/,
        type: 'asset/inline'
      },
      
      // asset/source:替代 raw-loader
      {
        test: /\.txt$/,
        type: 'asset/source'
      },
      
      // asset:自动选择(替代 url-loader)
      {
        test: /\.(png|jpg|gif)$/,
        type: 'asset',
        parser: {
          dataUrlCondition: {
            maxSize: 8 * 1024  // 8KB
          }
        }
      }
    ]
  }
};

五、迁移指南

file-loader → asset/resource

// 旧配置
{
  test: /\.(png|jpg)$/,
  use: {
    loader: 'file-loader',
    options: {
      name: 'images/[name].[hash:8].[ext]'
    }
  }
}

// 新配置
{
  test: /\.(png|jpg)$/,
  type: 'asset/resource',
  generator: {
    filename: 'images/[name].[hash:8][ext]'
  }
}

url-loader → asset

// 旧配置
{
  test: /\.(png|jpg)$/,
  use: {
    loader: 'url-loader',
    options: {
      limit: 8192,
      name: 'images/[name].[hash:8].[ext]'
    }
  }
}

// 新配置
{
  test: /\.(png|jpg)$/,
  type: 'asset',
  parser: {
    dataUrlCondition: {
      maxSize: 8 * 1024
    }
  },
  generator: {
    filename: 'images/[name].[hash:8][ext]'
  }
}

六、完整配置示例

module.exports = {
  module: {
    rules: [
      // 图片
      {
        test: /\.(png|jpg|jpeg|gif)$/,
        type: 'asset',
        parser: {
          dataUrlCondition: {
            maxSize: 10 * 1024  // 10KB
          }
        },
        generator: {
          filename: 'images/[name].[hash:8][ext]'
        }
      },
      
      // SVG
      {
        test: /\.svg$/,
        type: 'asset/inline'
      },
      
      // 字体
      {
        test: /\.(woff|woff2|eot|ttf|otf)$/,
        type: 'asset/resource',
        generator: {
          filename: 'fonts/[name][ext]'
        }
      },
      
      // 视频
      {
        test: /\.(mp4|webm)$/,
        type: 'asset/resource',
        generator: {
          filename: 'videos/[name].[hash:8][ext]'
        }
      }
    ]
  }
};

到此这篇关于Webpack file-loader与url-loader深度指南的文章就介绍到这了,更多相关Webpack file-loader url-loader 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript异步操作的方法小结

    JavaScript异步操作的方法小结

    在现代Web开发中,异步编程是不可或缺的一部分,JavaScript通过多种方式支持异步操作,允许开发者处理非阻塞代码执行,从而提高应用性能和响应速度,本文给大家介绍了JavaScript异步操作的常见方法,需要的朋友可以参考下
    2025-01-01
  • JS数据双向绑定原理与用法实例分析

    JS数据双向绑定原理与用法实例分析

    这篇文章主要介绍了JS数据双向绑定原理与用法,结合实例形式分析了JavaScript数据双向绑定相关原理、实现技巧与操作注意事项,需要的朋友可以参考下
    2019-11-11
  • 关于 文本框默认值 的操作js代码

    关于 文本框默认值 的操作js代码

    搜索框,文本框,文本域,文本区域 可能都要有个默认值
    2012-01-01
  • 在JavaScript中实现防抖和节流的方法详解

    在JavaScript中实现防抖和节流的方法详解

    文章介绍了防抖和节流的基本原理,提供了最常用的防抖和节流的实现代码,并附带了使用示例,同时,文章还讨论了带立即执行的防抖,以及如何快速记忆这两种技术,最后,文章提出可以为有需要的读者编写一个更高级的防抖节流版本,需要的朋友可以参考下
    2026-03-03
  • js Array对象的扩展函数代码

    js Array对象的扩展函数代码

    有时候我们需要对js的array对象扩展一些功能,这里简单介绍下,方便需要的朋友
    2013-04-04
  • javascript简单实现类似QQ头像弹出效果的方法

    javascript简单实现类似QQ头像弹出效果的方法

    这篇文章主要介绍了javascript简单实现类似QQ头像弹出效果的方法,可实现简单的页面元素弹出效果,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • 详解ES6实现类的私有变量的几种写法

    详解ES6实现类的私有变量的几种写法

    这篇文章主要介绍了详解ES6实现类的私有变量的几种写法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • 详解ES6 Symbol 的用途

    详解ES6 Symbol 的用途

    Symbol 唯一的用途就是标识对象属性,表明对象支持的功能。 这篇文章给大家介绍ES6 Symbol 的用途,感兴趣的朋友跟随小编一起看看吧
    2018-10-10
  • js点击button按钮跳转到另一个新页面

    js点击button按钮跳转到另一个新页面

    点击按钮怎么跳转到另外一个页面呢?点击图片要跳转到新的页面时,怎么做到呢?可以使用onclick=window.location=新页面来实现
    2014-10-10
  • JS实现简单计数器

    JS实现简单计数器

    这篇文章主要为大家详细介绍了JS实现简单计数器,有加、减和零三个按钮,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10

最新评论