前面講了不少理論,那麼這一節咱們將講一些實戰的例子git
先在命令行下輸入 node -v 檢查一下是否裝了node, 若是沒有請參考 https://github.com/joyent/node/wiki/Installing-Node.js-via-package-manager 安裝程序員
而後再用 npm -v 來確保Node.js 安裝正確github
咱們可使用npm來安排裝Gulp, 爲了能夠在命令行全局使用,咱們安裝到全局,另外確保其它的程序員可使用,咱們保存到項目的package.json裏npm
npm install gulp -g
建立一個文件目錄,而後創建對應的文件夾json
咱們先使用npm init來建立相似Nuget package的package.config同樣的文件,這樣咱們就知道項目依賴哪些插件,並且咱們不須要把插件提交到代碼庫,其它程序員只須要使用 npm install 就能夠安裝全部配置的插件gulp
而後咱們須要建立一個gulpfile.js文件,gulp默認是調用這個文件的。
咱們在目錄下使用
npm install gulp --save-dev # 這樣能夠把gulp安裝到本地
好比咱們想檢查咱們的js文件,那麼咱們須要安裝 gulp-jshint插件
npm install gulp-jshint --save-dev
而後添加一個test.js文件到src/scripts下,內容以下
var hi="hello" function sayHello(){ console.log("Jack "+hi) }
而後咱們修改gulpfile.js內容以下
// include gulp var gulp = require('gulp'); // include plug-ins var jshint = require('gulp-jshint'); // JS hint task gulp.task('jshint', function() { gulp.src('./src/scripts/*.js') .pipe(jshint()) .pipe(jshint.reporter('default')); });
而後運行
gulp jshint
看控制檯輸出就知道咱們少了分號。
咱們新建一個 ./scripts/b.js, 而後咱們把js文件合併而後壓縮並輸出到./build/scripts/all.js 下,同時移除debug信息
咱們須要安裝一下插件
npm install gulp-concat --save-dev npm install gulp-strip-debug --save-dev npm install gulp-uglify --save-dev
修改gulpfile.js
var gulp = require('gulp'); var concat = require('gulp-concat'); var stripDebug = require('gulp-strip-debug'); var uglify = require('gulp-uglify'); gulp.task('scripts', function() { gulp.src(['./src/scripts/*.js']) .pipe(concat('all.js')) .pipe(stripDebug()) .pipe(uglify()) .pipe(gulp.dest('./build/scripts/')); });
咱們看到gulp已經把咱們文件合併了,移除了console.log, 並且進行了壓縮。
至此,已經基本上知道gulp怎麼使用了,下面展現一些其它的功能的代碼
npm install gulp-autoprefixer --save-dev npm install gulp-minify-css --save-dev
示例代碼
var gulp = require('gulp'); var concat = require('gulp-concat'); var stripDebug = require('gulp-strip-debug'); var uglify = require('gulp-uglify'); var autoprefix = require('gulp-autoprefixer'); var minifyCSS = require('gulp-minify-css'); gulp.task('scripts', function() { gulp.src(['./src/scripts/*.js']) .pipe(concat('all.js')) .pipe(stripDebug()) .pipe(uglify()) .pipe(gulp.dest('./build/scripts/')); }); // CSS concat, auto-prefix and minify gulp.task('styles', function() { gulp.src(['./src/styles/*.css']) .pipe(concat('styles.css')) .pipe(autoprefix('last 2 versions')) .pipe(minifyCSS()) .pipe(gulp.dest('./build/styles/')); }); // default gulp task gulp.task('default', [ 'scripts', 'styles'], function() { // watch for JS changes gulp.watch('./src/scripts/*.js', function() { gulp.run('jshint', 'scripts'); }); // watch for CSS changes gulp.watch('./src/styles/*.css', function() { gulp.run('styles'); }); });
至此,你們應該熟悉gulp的使用,盡情去挖掘gulp plugin的寶藏吧。