Webpack第二弹之Loader

463 阅读4分钟

这是我参与11月更文挑战的第2天,活动详情查看:2021最后一次更文挑战

第一弹在这里:Weboack总结第一弹

Loader介绍

webpack做的事情,仅仅是分析出各种模块的依赖关系,然后整理成资源列表,最终打包生成到指定的文件中。

上一节我们说过,在webpack内部,任何文件都是模块,不仅仅是js文件。但是在默认情况下,在遇到requireimport的时候,webpack只支持对jsjson文件的打包,像cssscssjpg等这些类型的文件,webpack就无能为力了,这时候就用到了loader来对文件的内容进行解析

loader的定义:loader用于对模块的源代码进行转换,在import或加载模块时预处理文件

在加载模块时,执行顺序如下:

image-20211104120757749

当webpack碰到识别不了的文件时,就会从配置中找该文件的解析规则,来看个示例:

使用 loader 告诉 webpack 加载 CSS 文件,或者将 TypeScript 转为 JavaScript。为此,首先安装相对应的 loader:

npm install --save-dev css-loader ts-loader

然后指示 webpack 对每个 .css 使用 css-loader,以及对所有 .ts 文件使用 ts-loader

webpack.config.js

module.exports = {
  module: {
    rules: [
      // 将所有TypeScript 转为 JavaScript,
      // 也就意味着我们使用ts来开发,最终转换成js运行在浏览器端
      { test: /.ts$/, use: 'ts-loader' }
    ]
  }
};

module.rules 允许你在 webpack 配置中指定多个 loader。 这种方式是展示 loader 的一种简明方式,并且有助于使代码变得简洁和易于维护。同时让你对各个 loader 有个全局概览:

loader 从右到左(或从下到上)地取值(evaluate)/执行(execute)。在下面的示例中,从 sass-loader 开始执行,然后继续执行 css-loader,最后以 style-loader 为结束。

module.exports = {
  module: {
    rules: [
      {
        test: /.css$/,
        use: [
          // [style-loader](/loaders/style-loader)
          { loader: 'style-loader' },
          // [css-loader](/loaders/css-loader)
          {
            loader: 'css-loader',
            options: {
              modules: true
            }
          },
          // [sass-loader](/loaders/sass-loader)
          { loader: 'sass-loader' }
        ]
      }
    ]
  }
};

loader 特性

  • loader 支持链式调用。链中的每个 loader 会将转换应用在已处理过的资源上。一组链式的 loader 将按照相反的顺序执行。链中的第一个 loader 将其结果(也就是应用过转换后的资源)传递给下一个 loader,依此类推。最后,链中的最后一个 loader,返回 webpack 所期望的 JavaScript。
  • loader 可以是同步的,也可以是异步的。
  • loader 运行在 Node.js 中,并且能够执行任何操作。
  • loader 可以通过 options 对象配置(仍然支持使用 query 参数来设置选项,但是这种方式已被废弃)。
  • 除了常见的通过 package.jsonmain 来将一个 npm 模块导出为 loader,还可以在 module.rules 中使用 loader 字段直接引用一个模块。
  • 插件(plugin)可以为 loader 带来更多特性。
  • loader 能够产生额外的任意文件。

可以通过 loader 的预处理函数,为 JavaScript 生态系统提供更多能力。用户现在可以更加灵活地引入细粒度逻辑,例如:压缩、打包、语言转译(或编译)

常见的Loader

文件

  • val-loader 将代码作为模块执行,并将其导出为 JS 代码
  • ref-loader 用于手动建立文件之间的依赖关系

JSON

语法转换

模板

样式

框架

Awesome

有关更多第三方 loader,请参阅 awesome-webpack 中的列表。