codecamp

Parcel 资源类型

资源类型

正如 资源文档 里描述的,Parcel 将输入的文件看作 资源(Asset)。资源类型被看作继承自基准 Asset类的子类,并实现了必须的接口,去解析、分析依赖、转换及生成代码。

因为 Parcel 在多处理器内核中并行处理资源,因此资源类型所能够实施的转换行为,会被限制为那些可以  在单一时间内操作单一文件的转换行为。而那些需要操作多个文件的转换行为,则需要一个自定义的Packager

资源接口

const { Asset } = require('parcel-bundler')

class MyAsset extends Asset {
  type = 'foo' // 设置主要输出类型

  async parse(code) {
    // 将代码解析为 AST 树
    return ast
  }

  async pretransform() {
    // 可选。在收集依赖之前转换。
  }

  collectDependencies() {
    // 分析依赖
    this.addDependency('my-dep')
  }

  async transform() {
    // 可选。在收集依赖之后转换。
  }

  async generate() {
    // 生成代码。如有需要,可返回多个转换(renditions)。
    // 结果会传到合适的 packagers 去生成最终的 bundles
    return [
      {
        type: 'foo',
        value: 'my stuff here' // 主输出
      },
      {
        type: 'js',
        value: 'some javascript', // 如若需要,此转换内容可被放到 JS 的 bundle 中
        sourceMap
      }
    ]
  }

  async postProcess(generated) {
    // 所有代码生成后的过程
    // 可用于组合多种类型资源
  }
}

注册资源类型

你可以用 addAssetType 方法在打包工具中去注册你的资源类型。它接受一个文件扩展名,以及资源类型模块的路径。它是一个路径,而非实际的对象,这样可以使它被传至 worker 进程中。

const Bundler = require('parcel-bundler')

let bundler = new Bundler('input.js')
bundler.addAssetType('.ext', require.resolve('./MyAsset'))


Parcel 它如何运作
Parcel 插件
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }