前端構建大法 Gulp 系列 (四):gulp實戰

前面講了不少理論,那麼這一節咱們將講一些實戰的例子git

安裝Node.js

先在命令行下輸入 node -v 檢查一下是否裝了node, 若是沒有請參考 https://github.com/joyent/node/wiki/Installing-Node.js-via-package-manager 安裝程序員

而後再用 npm -v 來確保Node.js 安裝正確github

安裝 Gulp

咱們可使用npm來安排裝Gulp, 爲了能夠在命令行全局使用,咱們安裝到全局,另外確保其它的程序員可使用,咱們保存到項目的package.json裏npm

npm install gulp -g

建立項目

建立一個文件目錄,而後創建對應的文件夾json

  • src — 源文件:
    • images 
    • scripts 
    • styles 
  • build — 編譯後文件輸出到的生產文件夾:
    • images 
    • scripts 
    • styles 

咱們先使用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)
}

jshint 代碼檢查

而後咱們修改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的寶藏吧。

相關文章
相關標籤/搜索