rollup(下一代ES模块捆绑器)是什么请查看官网介绍http://rollupjs.org/guide/en/ 注意不要看Rollup.js 中文网,因为这是别人翻译的,不是实时更新的,我之前看这个老是安装出错

之前在网络上查找过相关的rollup使用,有些文章很概念不易理解,没有具体步骤;有些文章步骤不够详细,没有来龙去脉。所以打算整理个文章给后来者减少弯路。我保证此文真的是手把手教学,很接地气,因为我是边建工程边使用边写文章,不是某个项目里的代码,所以代码清晰,没有冗余。

为什么不用webpack

一说到打包工具大家都想到webpack,因为我们用到的vue,react脚手架都是基于webpack的,他有各种loader,帮助我们解决各种问题,这针对于开发项目是很有效的,但是他生成代码有很多是非我们所写的逻辑代码, 比如一些他自有的模块加载功能:
Rollup打包工具的使用 - 图1
如果你要开发js库,那webpack的繁琐和打包后的文件体积就不太适用了。有需求就有工具,所以rollup的产生就是针对开发js库的。
rollup生成代码只是把我们的代码转码成目标js并无其他,同时如果需要,他可以同时帮我们生成支持umd/commonjs/es的js代码,vue/react/angular都在用他作为打包工具。查看他们的官网代码都可以看到rollup的影子。

快速入门

1.新建工程

新建一个空文件夹,比如rollupConfigDemo

2.安装rollup

用vscode打开这个工程,执行命令安装

  1. cnpm install rollup --save-dev
  2. 复制代码

Rollup打包工具的使用 - 图2
执行后我们发现项目自动生产了一些文件,并看到package包里有了rollup。

添加gitignore,忽略不用上传的文件

Rollup打包工具的使用 - 图3

3.创建rollup.config.js

我们也可以不用配置文件直接用cli命令来打包,但是如果添加更多的选项,这种命令行的方式就显得麻烦。为此,我们可以创建配置文件来囊括所需的选项。配置文件由 JavaScript 写成,比 CLI 更加灵活。(cli命令打包请看官网介绍)

Rollup打包工具的使用 - 图4

4.编写要打包的文件

1.新建src文件夹,并新建main.js(应用程序入口)

Rollup打包工具的使用 - 图5

2.新建modules文件夹(代表模块文件)

modules的作用的区分模块和主入口,modules中可根据你自己的js库设计文件目录结构。

Rollup打包工具的使用 - 图6

5.编写package.json中的打包命令

Rollup打包工具的使用 - 图7

6.执行npm run build 查看文件输出结果

Rollup打包工具的使用 - 图8

我们看到输出的结果十分的清晰,没有像webpack那样多余的代码

7.使用打包后的文件

Rollup打包工具的使用 - 图9

打开这个网页后我们看到弹窗内容Hello from Rollup

常用配置

配置项简单说明

1.input

入口文件地址

2.output

  1. output:{
  2. file:'bundle.js', // 输出文件
  3. format: 'cjs, // 五种输出格式:amd / es6 / iife / umd / cjs
  4. name:'A', //当format为iife和umd时必须提供,将作为全局变量挂在window(浏览器环境)下:window.A=...
  5. sourcemap:true //生成bundle.map.js文件,方便调试
  6. }
  7. 复制代码

3.plugins

各种插件使用的配置

4.external

  1. external:['lodash'] //告诉rollup不要将此lodash打包,而作为外部依赖
  2. 复制代码

5.global

  1. global:{
  2. 'jquery':'$' //告诉rollup 全局变量$即是jquery
  3. }
  4. 复制代码

附一份react-redux开源项目的rollup配置文件

  1. import nodeResolve from 'rollup-plugin-node-resolve' // 帮助寻找node_modules里的包
  2. import babel from 'rollup-plugin-babel' // rollup 的 babel 插件,ES6转ES5
  3. import replace from 'rollup-plugin-replace' // 替换待打包文件里的一些变量,如process在浏览器端是不存在的,需要被替换
  4. import commonjs from 'rollup-plugin-commonjs' // 将非ES6语法的包转为ES6可用
  5. import uglify from 'rollup-plugin-uglify' // 压缩包
  6. const env = process.env.NODE_ENV
  7. const config = {
  8. input: 'src/index.js',
  9. external: ['react', 'redux'], // 告诉rollup,不打包react,redux;将其视为外部依赖
  10. output: {
  11. format: 'umd', // 输出 UMD格式,各种模块规范通用
  12. name: 'ReactRedux', // 打包后的全局变量,如浏览器端 window.ReactRedux 
  13. globals: {
  14. react: 'React', // 这跟external 是配套使用的,指明global.React即是外部依赖react
  15. redux: 'Redux'
  16. }
  17. },
  18. plugins: [
  19. nodeResolve(),
  20. babel({
  21. exclude: '**/node_modules/**'
  22. }),
  23. replace({
  24. 'process.env.NODE_ENV': JSON.stringify(env)
  25. }),
  26. commonjs()
  27. ]
  28. }
  29. if (env === 'production') {
  30. config.plugins.push(
  31. uglify({
  32. compress: {
  33. pure_getters: true,
  34. unsafe: true,
  35. unsafe_comps: true,
  36. warnings: false
  37. }
  38. })
  39. )
  40. }
  41. export default config
  42. 复制代码

深入使用

1.使用Babel

为了正确解析我们的模块并使其与旧版浏览器兼容,我们应该包括babel来编译输出。许多开发人员在他们的项目中使用 Babel ,以便他们可以使用未被浏览器和 Node.js 支持的将来版本的 JavaScript 特性。

1.1 安装 rollup-plugin-babel

  1. cnpm install rollup-plugin-babel --save-dev
  2. 复制代码

1.2 配置rollup.config.js

Rollup打包工具的使用 - 图10

1.3 添加Babel配置文件.babelrc

在src文件夹下添加.babelrc

Rollup打包工具的使用 - 图11
这个设置有一些不寻常的地方。

首先,我们设置 “modules”: false ,否则 Babel 会在 Rollup 有机会做处理之前,将我们的模块转成 CommonJS ,导致 Rollup 的一些处理失败。 第二,我们将 .babelrc 文件放在 src 中,而不是根目录下。 这允许我们对于不同的任务有不同的 .babelrc 配置,比如像测试,如果我们以后需要的话 - 通常为单独的任务单独配置会更好。

1.4 安装@babel/core 和 @babel/preset-env

@babel/core是babel的核心,我们看到babelrc配置了 preset env,所以要安装这两个插件

  1. cnpm install @babel/core @babel/preset-env --save-dev
  2. 复制代码

安装后我们看到package包内容
Rollup打包工具的使用 - 图12
最后运行npm run build,我们看到打包后出来的文件内容经过babel转换后有es6语法变成了es5语法
Rollup打包工具的使用 - 图13

2.node模块的引用

在某些时候,您的项目可能取决于从NPM安装到node_modules文件夹中的软件包。 与Webpack和Browserify等其他捆绑软件不同,Rollup不知道如何``开箱即用’’如何处理这些依赖项-我们需要添加一些插件配置。 rollup.js编译源码中的模块引用默认只支持 ES6+的模块方式import/export。然而大量的npm模块是基于CommonJS模块方式,这就导致了大量 npm 模块不能直接编译使用。所以辅助rollup.js编译支持 npm模块和CommonJS模块方式的插件就应运而生。

  • rollup-plugin-node-resolve 插件允许我们加载第三方模块
  • @rollup/plugin-commons 插件将它们转换为ES6版本

    2.1 安装@rollup/plugin-node-resolve和@rollup/plugin-commonjs

    1. cnpm install @rollup/plugin-node-resolve @rollup/plugin-commonjs --save-dev
    2. 复制代码

    如果你安装了rollup-plugin-commonjs,安装后会提示

Rollup打包工具的使用 - 图14

意思是说此包已被弃用,不再维护。请使用@rollup/plugin commonjs. 如果你安装了rollup-plugin-node-resolve可能也会遇到这个情况,解决方案类似。英文官网里都是用的@rollup/plugin-node-resolve和@rollup/plugin-commonjs

安装后包内容为
Rollup打包工具的使用 - 图15

2.2 配置rollup.config.js

Rollup打包工具的使用 - 图16

2.3 使用一个第三方库lodash

  1. cnpm install lodash --save-dev
  2. 复制代码

打开src/main.js使用lodash

Rollup打包工具的使用 - 图17

执行npm run build 后我们看打包后的文件多了很多内容,这些代码就是ladash的代码,被我们打包整合进来了。

Rollup打包工具的使用 - 图18

打开网页查看输出内容

Rollup打包工具的使用 - 图19

2.4 额外补充

如果你不想第三方库被打包进来,而可以在外面引入,配合使用的话,可以在rollup.config.js中配置external

Rollup打包工具的使用 - 图20

执行npm run build 后发现打包出来的内容变少了

Rollup打包工具的使用 - 图21

然后页面里使用也稍作修改,script引入lodash,使用iife打包出来的文件(因为我们这里使用页面引用的方式),查看页面可以正常输出。

Rollup打包工具的使用 - 图22

3.使用typescript

我们在开发大型项目时,一般都会使用typescript来增强代码的可维护性。所以在rollup中使用typescript也是必不可少的。

3.1 安装@rollup/plugin-typescript

我之前使用的时候用的是rollup-plugin-typescript,今天写这篇文章时发现此插件不维护更新了,模块移植到了@rollup/plugin-typescript

Rollup打包工具的使用 - 图23

  1. cnpm install @rollup/plugin-typescript --save-dev
  2. 复制代码

安装后发现有报错,提示我们要安装tslib和typescript

Rollup打包工具的使用 - 图24

3.2 安装tslib 和 typescript

  1. cnpm install tslib typescript --save-dev
  2. 复制代码

安装好后我们来看看package包内容

Rollup打包工具的使用 - 图25

3.3 配置rollup.config.js

引入使用插件

Rollup打包工具的使用 - 图26

3.4 配置tsconfig.json

如果不配置直接运行npm run build 会有提示让我们新建tsconfig配置

Rollup打包工具的使用 - 图27

3.5 编写ts文件

Rollup打包工具的使用 - 图28Rollup打包工具的使用 - 图29

运行npm run build 后,查看页面能正常解析和运行

Rollup打包工具的使用 - 图30

4.压缩代码

为了时代码体积更小,我们都会使用代码压缩插件

4.1 安装rollup-plugin-terser

terser是什么,它是适用于ES6 +的JavaScript解析器,mangler和压缩器工具包 我们比较熟悉的是uglify,因为我们在webpack中使用过,rollup中也有rollup-plugin-uglify插件

Rollup打包工具的使用 - 图31

我们看到 注意:uglify-js只能翻译es5语法。如果要转译es6+语法,请改用terser 所以我们使用rollup-plugin-terser

  1. cnpm install rollup-plugin-terser --save-dev
  2. 复制代码

4.2 配置rollup.config.js

Rollup打包工具的使用 - 图32

引入使用了terser后,我们执行npm run buld,看看输出结果

Rollup打包工具的使用 - 图33

5.编译css

开发项目我们用webpack,开发js类库,rollup比webpack强。开发js类库一般是不写css,如果你要写大量的css,那可能你开发的是项目,优先选择webpack,webpack里也有开发library的配置。 如果你的js类库里还是必不可少要写些css的话,rollup也是有插件编译css的

5.1 安装rollup-plugin-postcss

  1. cnpm install rollup-plugin-postcss --save-dev
  2. 复制代码

5.2 配置rollup.config.js

引入postcss插件并使用,先注释掉压缩插件,让我们能看看打包出来的css会是什么样的。

Rollup打包工具的使用 - 图34

5.3 编写使用css

1.在src目录下写入style.css文件

Rollup打包工具的使用 - 图35

2.main.js中写入相关的css使用代码

Rollup打包工具的使用 - 图36

3.执行npm run build 查看打包后的文件内容。我们看到css通过这块代码动态引入了

Rollup打包工具的使用 - 图37

4.打开页面查看html代码

Rollup打包工具的使用 - 图38

使用less等预编译也是可以的,如有需要,向我提问我再更新。

6.开启本地服务器

在实际开发过程中,我们肯定要运行代码,查看页面,这时有个本地服务器就很重要,这样可以调试代码。

6.1 安装rollup-plugin-serve

  1. cnpm install rollup-plugin-serve --save-dev
  2. 复制代码

6.2 配置rollup.config.js

记得配置sourcemap: true,这样调试代码方便。
Rollup打包工具的使用 - 图39
记得在根目录下建一个index.html文件来引用js类库
Rollup打包工具的使用 - 图40
在package.json中配置命名(这里做了修改,区分了开发环境和生产环境,这个配置请看下文)
Rollup打包工具的使用 - 图41

7.开启热更新

现在本地服务器有了,但是每次修改代码,还要重新启动才能生效,很不方便,所以需要热更新。

7.1 安装rollup-plugin-livereload

  1. cnpm install rollup-plugin-livereload --save-dev
  2. 复制代码

7.2 配置rollup.config.js

Rollup打包工具的使用 - 图42

8.区分开发环境和生产环境

在开发环境我们需要sourcemap开启,配置热更新和本地服务,在生产环境我们需要sourcemap关闭,不需要热更新和本地服务,需要代码压缩等,所以需要区分。

8.1将rollup.config.js拆分成两个rollup.config.dev.js和rollup.config.build.js

Rollup打包工具的使用 - 图43

8.2修改 package.json 中的打包命名

Rollup打包工具的使用 - 图44

持续更新

github.com/rollup/plug… github.com/rollup/awes… 这两个rollup插件相关的插件地址,想要的功能来这找

来源