What is Gulp
Gulp is a streaming build system which is usually used to simplify front-end development workflow, such as automatically minifying JavaScript or compiling LESS. In this tutorial, you’ll learn the basic usage of Gulp.
Preparation
To make sure you’ll have fun following my instructions, I assume you:
- have node.js & npm installed
- have basic knowledge of node.js scripting.
Installing Gulp
Let’s start with the installation of Gulp.
Run the following command in your shell terminal. The installation requires sudo or root previlege and you may be required to enter the password.1
$ sudo npm install --global gulp
Project Setup
cd
into the root directory of your project and run the following command, which will save the Gulp dependencies in your project directory.1
$ npm install --save-dev gulp
Create gulpfile.js
At the root of your project, create a gulpfile.js
containing the following code.
1 | var gulp = require('gulp'); |
The code above defines a gulp task named “mytask” with the detailed commands defined in the callback function as the second parameter passed to the gulp.task()
method. When running this task, console.log('Hello World!');
will be executed.
Testing
Now you should be able to run mytask
using the following command:1
$ gulp mytask
Assume the root directory of your project is ~/project
, the output should be like:1
2
3
4
5➜ project gulp mytask
[21:14:25] Using gulpfile ~/project/gulpfile.js
[21:14:25] Starting 'mytask'...
Hello World!
[21:14:25] Finished 'mytask' after 62 μs
You can always run specific tasks by executing gulp <task> <other_task>
Basic File Streaming
In this section we’ll use Gulp’s streaming system which is its primary function.
We will use Gulp.src()
, Gulp.dest()
, readable.pipe()
to implement a basic JavaScript source file copying program using Gulp.
For detailed API doc of the methods above, please refer to Gulp API doc and Node.js:Stream.
- Create a directory named
js
at the root of your project (Assume you created this directory:~/project/js
) and place some JavaScript files in it. Add the following code at the end of
gulpfile.js
1
2
3
4gulp.task('copyjs',function(){
gulp.src('js/*.js')
.pipe(gulp.dest('dest'));
});At the root of the project which is
~/project
, run:1
$ gulp copyjs
Check out
~/project/dest
to which you’ll find all js files in~/project/js
are copied.
Using Gulp to Minify JS
Next we’ll use Gulp to do some amazing tasks which bring great convenience for front-end development.
Let’s start with JavaScript minifying.
To make Gulp powerful enouth to do this job, we must install some plugins of Gulp. Here we’ll use gulp-uglify.(For more amazing gulp plugins, check out Gulp Plugins)
Back to
~/project
, run the following command to install gulp-uglify.1
$ npm install --save-dev gulp-uglify
Replace
gulpfile.js
with the following code.1
2
3
4
5
6
7
8var gulp = require('gulp');
var uglify = require('gulp-uglify');
gulp.task('minifyjs', function(){
gulp.src('js/*.js') //Get the stream of the source file
.pipe(uglify())//Pass the stream to the uglify module to minify all JS files.
.pipe(gulp.dest('build'));//Pass the stream to the destination directory which is ~/project/build
});Exucute the task by running:
1
$ gulp minifyjs
Check out
~/project/build
. All minified JavaScript source files are placed here!
Using Gulp.watch()
Sometimes we want the JS files to be automatically minified everytime we modify them and Gulp.watch()
will do the trick.Gulp.watch()
allows us to implement a daemon to monitor file modifications and automatically execute specific tasks every time the modifications are made.
Add the following code at the end of
gulpfile.js
.1
2
3gulp.task('watchjs', function(){
gulp.watch('js/*.js',['minifyjs']); //Watch all *.js files under ~/project/js directory and run task "minifyjs" when files are modified
});Execute the daemon task by running:
1
$ gulp watchjs
Now, JS files will be automatically minified every time you modify them.