【译】React.js教程 第二部分:使用Gulp自动化构建工具
技术系列笔记均已迁移至 GitBook,更多React
的内容请到:http://jimmylv.gitbooks.io/learning-react-js/content/reactjs_tutorial/reactjs_tutorial_part_1.html
React.js Tutorial Part 2
原文地址:http://www.joshfinnie.com/blog/reactjs-tutorial-part-2/
Welcome to part 2 of my tutorial on how to get a website up and running using React.js and Node.js. You can read Part 1 here if you haven’t already.
欢迎来到如何使用React.js搭建网站教程的第二部分不,如果你还没有阅读第一部分,戳这里。
In this part of the tutorial, we are going to make our React.js/Express.js app more like a full-fledged web application with the addition of a build system called Gulp.js. Gulp.js is a build system (or task runner) that I have been using for a while. There are many, many, many out there, but I find Gulp.js to be very sufficient for my needs.
这一部分,我们将使用额外的Gulp.js构建工具,搭建一个更加完善的 React.js/Express.js 应用。Gulp.js 是一个我一直在使用的构建工具(任务管理器),这里有很多类似的gruntjs, broccoli, webpack等工具,但是最终发现 Gulp.js 最符合需求。
Installing Gulp | 安装 Gulp
Installing Gulp is very similar as to how we installed Express in the last tutorial, we need to add the--save-dev
flag to save gulp to ourdevDependencies
portion of thepackage.json
file. Run:
安装 Gulp 非常简单,就像上个教程中安装 Express 一样。使用--save-dev
标记将 gulp 保存到package.json
文件的devDependencies
部分,运行:
$ npm install --save-dev gulp
Now with Gulp installed, we can create our basic gulpfile.js
file:
Gulp 安装好之后,我们建立一个gulpfile.js
文件:
var gulp = require('gulp')
gulp.task('default', function () {
// place code for your default task here
})
Now we need to install the Gulp packages that we will need to build our application. To start, let’s install browserify, reactify and vinyl-source-stream. To install these packages, run the following command:
现在需要为我们的应用安装 Gulp 包,开始之前,让我们添加browserify,reactify和vinyl-source-stream。运行:
$ npm install --save-dev react browserify reactify vinyl-source-stream
At this point, we can removereact-tools
from ourdevDependencies
since we no longer need to build our.jsx
files via the command line. YourdevDependencies
should look like this:
在这时,我们可以从devDependencies
中删除react-tools
,因为我们不再需要通过命令行手动编译.jsx
文件了。
"devDependencies": {
"browserify": "^8.1.3",
"gulp": "^3.8.10",
"react": "^0.12.2",
"reactify": "^1.0.0",
"vinyl-source-stream": "^1.0.0"
}
Setting up Gulp | 设置 Gulp
The next step is to set up Gulp to automatically build our.jsx
files into usable javascript. To do this, we are going to create a Gulp task. A Gulp task is a function that will stream a bunch of steps transforming our.jsx
to javascript. We will need to modify ourgulpfile.js
to look like this:
下一步就是编写 Gulp 任务来将.jsx
文件自动编译成可用的 JavaScript 文件。一个 Gulp 任务就是一个函数,包含编译文件的一系列步骤。我们需要修改gulpfile.js
:
var gulp = require('gulp')
var browserify = require('browserify')
var reactify = require('reactify')
var source = require('vinyl-source-stream')
gulp.task('js', function () {
browserify('./public/javascripts/src/app.jsx')
.transform(reactify)
.bundle()
.pipe(source('app.js'))
.pipe(gulp.dest('public/javascripts/build/'))
})
gulp.task('default', ['js'])
Now running gulp
from the command line will trigger the build of our React app; however, there are some things we need to do to our react app first!
现在从命令行中运行gulp
就会自动编译我们的 React 应用。但是,还有一些事情需要做!
Browserifying React | 将 React 浏览器化
There are some things we need to do to our application before browserify will work. Last tutorial we wrote a helloworld.jsx
, now we need to modify this slightly to work with browserify. If you don’t know browserify is a tool for compiling node-flavored commonjs modules for the browser. So let’s modify our React code to work with browserify.
在 browserify 可以工作之前需要做一些事情,在上一节中编写了helloworld.jsx
,现在我们需要稍微修改一下。browserify 是一个工具,可以将 node 模块编译成浏览器可执行的 commonjs 模块。
First, we need to create an “entry point” for browersify, we can do this by simply creating an app.jsx
file:
首先,我们需要为 browersify 创建一个入口,建立一个app.jsx
文件就可以了:
var React = require('react')
var HelloWorld = require('./HelloWorld.jsx')
React.render(<HelloWorld />, document.getElementById('example'))
This file is taking ourHelloWorld
component and rendering it in the div with id “example”. This code is taken from our originalhelloworld.jsx
file from last tutorial. Instead of doing everything in that file, we are now requiring a moduleHelloWorld
and rendering it inapp.jsx
. The reason for this is that as our application gets more complex, we have more control of how our files are broken out.
这个文件就是一个HelloWorld
组件,可以被渲染到id="example"
的 div 标签中,这份代码是直接从上一个教程的helloworld.jsx
文章拿到的。但现在不是在一个文件中做所有事情,而是将HelloWorld
模块渲染到app.jsx
中。
The next thing is that we have is modify our existinghelloworld.jsx
file to be a React component namedHelloWorld.jsx
. This is easily done and ourHelloWorld.jsx
file now looks like this:
下一件事是已有的helloworld.jsx
文件修改成 React 组件,HelloWorld.jsx
:
var React = require('react')
module.exports = React.createClass({
render: function () {
return <h1>Hello, world from a React.js Component!</h1>
},
})
Notice that theHelloWorld.jsx
andapp.jsx
files are combined to be very similar to how the ‘helloworld.jsx’ looked. Again, the reason for breaking our app into these two files are for future modules to be added.
注意到HelloWorld.jsx
和app.jsx
文件组合在一起,看起来很像单独的’helloworld.jsx’文件。原因是为了将我们的应用拆分成不同的模块,以便于未来的可扩展性。
Now, runninggulp
will create a javascript file inpublic/javascripts/build/
calledapp.js
and it will have everything we need to run our React app. Let’s add this to ourlayout.jade
file instead of thereact.min.js
andhelloworld.js
files:
现在运行gulp
会在public/javascripts/build/
目录中新建名为app.js
的标准 JavaScript 文件,我们需要它来运行 React 应用。让我们添加到layout.jade
,替换之前的react.min.js
和helloworld.js
文件:
doctype html
html
head
title= title
link(rel='stylesheet', href='/stylesheets/style.css')
body
block content
script(src='/javascripts/build/app.js')
There you have it, a React application being built with Gulp using browersify!
现在就有了一个使用 Gulp 自动构建 browersify 的 React 应用啦!
Gulp Watch | Gulp 监控
To make Gulp even better, let’s implement the built-inwatch
functionality to have gulp watch for changes in our.jsx
files and automatically build our javascript. To do this, we want to add the following task to ourgulpfile.js
:
为了更好得使用 Gulp,我们可以实现一个内建的watch
功能,能够自动监测和编译.jsx
文件。添加任务:
gulp.task('watch', function () {
gulp.watch('public/javascripts/src/**/*.jsx', ['js'])
})
Also add that task to your default Gulp task:
同时将watch
任务添加到默认任务中:
gulp.task('default', ['js', 'watch'])
Now when we rungulp
it will watch for changes in our.jsx
and rebuild our javascript with that change! Awesome!
现在我们可以运行gulp
来自动监控.jsx
的变化,并且自动重新编译成标准的 JavaScript,Awesome!
Next Time | 下一次
Next time we will continue to use Gulp to build out some more niceties when building a web application, introduce Bower, and finally get to building some of the React Components we will use in our job board.
下一次我们将继续使用 Gulp 来构建开发 web 应用时的其他细节,介绍Bower,最终为我们的工作布告栏应用的编写 React 组件。