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


前面講了很多理論,那么這一節我們將講一些實戰的例子

安裝Node.js

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

然后再用 npm -v 來確保Node.js 安裝正確

安裝 Gulp

我們可以使用npm來安排裝Gulp, 為了可以在命令行全局使用,我們安裝到全局,另外確保其它的程序員可以使用,我們保存到項目的package.json里

npm install gulp -g

創建項目

創建一個文件目錄,然后建立對應的文件夾

  • src — 源文件:

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

    • images
    • scripts
    • styles

我們先使用npm init來創建類似Nuget package的package.config一樣的文件,這樣我們就知道項目依賴哪些插件,而且我們不需要把插件提交到代碼庫,其它程序員只需要使用 npm install 就可以安裝所有配置的插件

然后我們需要創建一個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的寶藏吧。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM