webpack 中的 file-loader 和 url-loader

更新日期: 2019-08-23阅读: 2.1k标签: loader

1. file-loader

// index.js
import doggy from 'doggy.jpg'

console.log(doggy)
// webpack.config.js
module.exports = {
  // 省略其他配置项
  module: {
    rules: [{
      test: /\.(png|jpg|gif)$/,
      use: {
        loader: 'file-loader'
      }
    }]
  }
}

打包后,file-loader 将 doggy.jpg 移动到了 dist 目录下,并将该图片改名为 11e15173d7f38a223d340822e4364ddb.jpg。

通过配置 name 和 outputPath 选项,可以自定义图片名称和路径。

loader: 'file-loader',
options: {
  name: '[name].[ext]?[hash]',
  outputPath: 'images/'
}

打包后,dist 目录下会生成一个 images 文件夹,里面包含了 doggy.jpg?e43b20c069c4a01867c31e98cbce33c9。

更多 file-loader 的可配置选项及其他内容,参考 file-loader


2. url-loader

url-loader 将图片转化成 base 编码字符串和 main.js 打包在一起。

// webpack.config.js
module.exports = {
  // 省略其他配置项
  module: {
    rules: [{
      test: /\.(png|jpg|gif)$/,
      use: {
        loader: 'url-loader',
        options: {
          limit: 8192
        }
      }
    }]
  }
}

上述代码设置了 limit 选项,意思是当图片体积小于 8192 字节时,会转换成 base 编码字符串,当图片体积大于 8192 字节时,默认会使用 file-loader,并且会将配置的选项传递给 file-loader(也就是说上面可以配置 name、outputPath 等选项)。

url-loader 默认 limit 是没有限制,如果没有设置,则不管多大的图片都会转换为 base64 编码字符串。

还可以配置 fallback 选项来指定不满足 limit 条件时应当使用的 loader:

loader: 'url-loader',
options: {
  limit: 8192,
  fallback: 'responsive-loader'
}

更多 url-loader 的可配置选项及其他内容,参考 url-loader


链接: https://www.fly63.com/article/detial/5494

webpack中loader加载器的使用及原理

webpack的loaders是一块很重要的组成部分。我们都知道webpack是用于打包的,里面的所有资源都是“模块”,内部实现了对模块资源进行加载的机制。loader的作用为了转换应用程序的资源文件。

vue-cli项目报错Invalid CSS after ...load the styles解决方案_loader重复加载

知道在webpack中使用scss,less之类的东西,需要配置style-loader, css-loader, sass-loader这些,但是在vue-cli的项目中会报Invalid CSS after ...load the styles的错误,这是由于loader重复加载导致的。

webpack之理解loader

我们在写webpack配置文件的时候,应该有注意到经常用到loader这个配置项,那么loader是用来做什么的呢?loader其实是用来将源文件经过转化处理之后再输出新文件。

移动端适配的两种方案及flexible和px2rem-loader在webpack下的配置

方案一:使用lib-flexible包:使用flexible包方式,安装 lib-flexible 包和 px2rem-loader包;方案二:使用less或者sass等CSS 预处理语言写适配方案:基准按照设计图尺寸,但是缺点是不通用,不同页面可能设计图基准尺寸不同

webpack中的 loader 是什么?

那是因为,webpack 默认只支持打包 Javascript 模块,比如 import m1 from m1.js,而对于引入了图片模块,webpack 并不知道该如何处理,因此在打包的时候就报错了。对于上述打包图片资源报错的问题

Babel-loader,babel-core和babel-preset之间是什么关系

`babel-loader` 是一个 npm 包,它使得 webpack 可以通过 babel 转译 JavaScript 代码。babel 的功能在于「代码转译」,具体一点,即将目标代码转译为能够符合期望语法规范的代码。在转译的过程中

分享12个Webpack中常用的Loader

整理一些常用的loader分享给大家,方便知道在什么场景下该用什么loader。如果有大佬都懂悄悄左滑就行,不喜勿喷。style-loader用于将css编译完成的样式,挂载到页面style标签上。

项目性能优化之用url-loader把小图片转base64,大图片使用image-webpack-loader压缩

项目中常常会引入一些图片资源,什么jpg|jpeg|png|gif|ico之类的,正常情况下,我们需要做一下性能优化,看看如何大而化小、小而化了,提升生产环境资源加载速度。所以,本文记录一下大图片使用image-webpack-loader插件压缩一下

可能改变前端工程化未来的特性:ESM Loader Hooks

用过webpack的朋友一定知道webpack中有个loader的概念,用于加载并处理不同类型文件,比如css-loader、url-loader。loader的执行顺序取决于webpack内部对文件树解析、遍历的顺序。

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!