📦 Packagers

在 Parcel 中,一个 Packager 将多个 资源合并到一个最终生成的 bundle 中。此过程发生在主进程中,且在所有资源被处理及 bundle 树被创建之后。Packager 的注册是基于输出文件类型,并且用于生成这种文件类型的资源会被送到 packager 中去生成最后生成的输出文件。

Packager 接口

  1. const { Packager } = require('parcel-bundler')
  2. class MyPackager extends Packager {
  3. async start() {
  4. // 可选,写文件头部内容
  5. await this.dest.write(header)
  6. }
  7. async addAsset(asset) {
  8. // 必须。将资源写入生成文件。
  9. await this.dest.write(asset.generated.foo)
  10. }
  11. async end() {
  12. // 可选,写文件尾内部内容。
  13. await this.dest.end(trailer)
  14. }
  15. }

注册一个 Packager

你可以用 addPackager 方法在打包工具中注册一个 packager。它接受一个文件类型及 packager 模块的所在路径用于注册。

  1. const Bundler = require('parcel-bundler')
  2. let bundler = new Bundler('input.js')
  3. bundler.addPackager('foo', require.resolve('./MyPackager'))

帮助我们改善文档

如果有遗漏或者不清楚的地方,请在本站的仓库 提交issue 或者 编辑此页面.