[关闭]
@zhouweicsu 2015-10-15T14:29:44.000000Z 字数 1326 阅读 885

使用 Browserify, Babel & hot reloading 快速构建 ES2015 工程

ES6 Browserify Babel


现在又很多 ES2015 和 React 工程的新手工具包。如果你想快速构建一个原型或者只是想玩一玩代码,那配置肯定越少越好。必备工具集有: transpiler(编译工具), bundler(打包工具) 和 hot reloader(热重载)(因为是2015,所以你肯定不希望在重新加载页面上浪费时间)。Browserify 是一个非常棒并且使用起来很简单的 bundler 。更重要的是——它是模块化的,这样你就能在任意时间连接 plugins 和 transforms。Babel 是我们选择的 transpiler,无论你是否使用React,它都很好用。hot reloader 是为了提高开发效率。相对于手动或自动重新加载整个页面,hot reloader 仅仅让浏览器更新部分代码。因此它会很快,并且可以保持应用程序状态,所以你不需要重复之前的操作回到原来的UI状态。本文的例子不是介绍另一个新手工具包,而是教你如何以最少的必备工具开始 ES2015 工程。

新建一个 package.json 并且安装下面的 packages:

  1. $ npm i -D browserify babelify watchify serve

前三个是 bundler, Babel插件 和 文件监视器, serve 包是一个静态服务器。

将如下代码添加至package.json,这样 Browserify 就会在指定的 stage 下使用 Babel 编译器。

  1. {
  2. "browserify": { "transform": [ ["babelify", {"stage": [0]}] ]
  3. }

最后,这里有一段 NPM 脚本使用 source maps 来启动 bundler 并进入监视模式,且在指定的目录下启动静态服务器。

  1. "scripts": {
  2. "start": "watchify src/index.js -o public/js/bundle.js -dv & serve public"
  3. }

在热模块替代方面,我选择 Browserify 安装如下插件与必备包来重新加载 React 组件:

  1. $ npm i -D livereactload react-proxy babel-plugin-react-transform

新建 .babelrc 文件并添加以下内容。这个会告诉 Babel transform 使用已经安装过的插件。

  1. {
  2. "env": {
  3. "development": {
  4. "plugins": [ "react-transform" ],
  5. "extra": {
  6. "react-transform": {
  7. "transforms": [{
  8. "transform": "livereactload/babel-transform",
  9. "imports": ["react"]
  10. }]
  11. }
  12. }
  13. }
  14. }
  15. }

现在将livereactload插件加入 NPM 脚本,然后你就可以开始愉快的玩耍了。

  1. "scripts": {
  2. "start": "watchify src/index.js -o public/js/bundle.js -dv -p livereactload & serve public"
  3. }

若要开发产品或者获取更多深入资料,请访问 GitHub, 你会找到海量现成的模板。

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注