使用rollup打包库的一种基本配置

栏目: JavaScript · 发布时间: 5年前

内容简介:Rollup 是一个 JavaScript 模块打包器。它会对符合js的ES6模块的文件进行打包(非ES6模块如commonjs模块需要插件先转化为es6模块)。另外,Rollup会自动的进行tree shaking,有效的降低代码体积。然而,Rollup暂还不支持码拆分和运行时态的动态导入,所以更适合用作library的打包器。每次写类库都需要完成大量的基础配置,babel代码,各种格式化工具,提交时的规范等。所以,创建了写一个类库时需要的基本的rollup配置,降低后续开发library的成本。 如果不

Rollup 是一个 JavaScript 模块打包器。它会对符合js的ES6模块的文件进行打包(非ES6模块如commonjs模块需要插件先转化为es6模块)。另外,Rollup会自动的进行tree shaking,有效的降低代码体积。然而,Rollup暂还不支持码拆分和运行时态的动态导入,所以更适合用作library的打包器。

每次写类库都需要完成大量的基础配置,babel代码,各种格式化工具,提交时的规范等。所以,创建了写一个类库时需要的基本的rollup配置,降低后续开发library的成本。 如果不了解基本的使用规则,可以查看Rollup.js官网

关于模板

模板的使用

git clone https://github.com/banyaner/rollup_template.git
复制代码
  1. 修改package.json文件中的所有'rollup_template'为你的模块的名字
  2. 模板默认会打包es6和commonjs模块。如果需要打包同时支持多种环境的模块,请看下一节
  3. 模板使用prettier在git add时自动格式化代码
  4. 模板在git commit时强制使用angular的commit规范使用standard version发布代码使用方法。
  5. package.json中main字段为iife函数,module默认为基于浏览器环境进行打包。另外,也会打包出对应的其他类型的模块(node环境和commonjs模块)。可以按照项目需求手动修改。代码中通过 process.browser 判断是否为浏览器环境,从而在生成代码时更好的缩减代码。具体的使用可以看文章 [译] 怎样写一个能同时用于 Node 和浏览器的 JavaScript 包?

关于package.json中的main、module、browser字段。

Rollup支持打包出ES6、CommonJS、UMD模块.

{
  "main": "dist/rollup_template.cjs.js",
  "module": "dist/rollup_template.esm.js",
  "browser": "rollup_template.umd.js"
}
复制代码

Webpack和Rollup都会对ES6模块做静态优化(tree shaking 和 scope hoisting),所以他们均会有限使用module字段作为引入资源的入口,如果没有module才读取main字段作为CommonJS的入库。所以: module 字段指向ES6的模块;main指向CommonJS模块。 但是如果你写的模块需要同时支持在Node.js与浏览器运行,则需要使用browser来字段。 browser字段有两种使用方式:

  1. 写入一个umd文件地址,如上面的示例。这种将会把所有的node端和浏览器端的代码都打包进去。(也就意味着如果你的项目只在浏览器端运行的话,代码里也可能还会有冗余的node端代码)。注意: 使用这种方式后,打包 工具 会忽略module字段,从而无法进行静态优化
  2. 如果你只需要部分文件做替换,可以使用对象。但前面提到的文章已经说明了这种方式的不友好,所以我们模板中采用了 rollup-plugin-replace 来自动的实现文件的分别打包浏览器和node环境代码。也就不需要使用browser字段了.

以上所述就是小编给大家介绍的《使用rollup打包库的一种基本配置》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

社交红利2.0

社交红利2.0

徐志斌 / 中信出版社 / 2015-9 / 42元

大型社交网络发展至今,开始显露出更为惊人的力量。有一个独特现象与这一结果相伴相生,即新应用或服务一进入社交网络就即时引爆,就像用户在等待它出现一样。随即开始的病毒式扩散,让创业者成为全民话题的焦点。但这一切是如何实现的?具备哪些特征的合作伙伴才可以被即时引爆? 作者从其长期追踪的近30个一进入微博、微信就引爆的经典案例中甄选出若干典型案例。从大量一手鲜活的后台数据入手,并结合腾讯对社交网络的......一起来看看 《社交红利2.0》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具