Gulp學習指南之CSS合並、壓縮與MD5命名及路徑替換


 

npm init
//- 生成一個 package.json,里面是一些常規的配置信息

npm install gulp gulp-concat gulp-minify-css gulp-rev gulp-rev-collector --save-dev
//- 安裝插件到項目目錄內

 

 gulpfile.js

var gulp = require('gulp');

var concat = require('gulp-concat');                            //- 多個文件合並為一個;
var minifyCss = require('gulp-minify-css');                     //- 壓縮CSS為一行;
var rev = require('gulp-rev');                                  //- 對文件名加MD5后綴
var revCollector = require('gulp-rev-collector');               //- 路徑替換

gulp.task('cssConcat', function() {                                //- 創建一個名為 concat 的 task
    gulp.src('./src/css/*.css')    //- 需要處理的css文件,放到一個字符串數組里
        .pipe(concat('style.min.css'))                            //- 合並后的文件名
        .pipe(minifyCss())                                      //- 壓縮處理成一行
        .pipe(rev())                                            //- 文件名加MD5后綴
        .pipe(gulp.dest('./build/css'))                               //- 輸出文件本地
        .pipe(rev.manifest())                                   //- 生成一個rev-manifest.json
        .pipe(gulp.dest('./rev'));                              //- 將 rev-manifest.json 保存到 rev 目錄內
});

gulp.task('rev',['cssConcat'],function() {console.log(111)
    gulp.src(['./rev/rev-manifest.json', './src/index.html'])   //- 讀取 rev-manifest.json 文件以及需要進行css名替換的文件
        .pipe(revCollector())                                   //- 執行文件內css名的替換
        .pipe(gulp.dest('./build/'));                     //- 替換后的文件輸出的目錄
});
gulp.watch('./src/**/*',['rev'])
gulp.task('default', [ 'rev']);

 

運行結果

通過以上的配置之后,就可以開始運行 gulp 對我們的項目進行相關的操作啦;

使用 gulp 命令,運行Gulp.js 構建程序

首先運行 concat 這個 task 生成一個 rev-manifest.json 文件
然后再運行 rev 這個 task 替換掉文件中引入的 css

YuanWingdeMacBook-Pro:m YuanWing$ gulp concat
[11:47:02] Using gulpfile ~/SVN/JKD/m/gulpfile.js
[11:47:03] Starting 'concat'...
[11:47:03] Finished 'concat' after 12 ms
YuanWingdeMacBook-Pro:m YuanWing$ gulp rev
[11:47:17] Using gulpfile ~/SVN/JKD/m/gulpfile.js
[11:47:17] Starting 'rev'...
[11:47:17] Finished 'rev' after 10 ms
YuanWingdeMacBook-Pro:m YuanWing$ 

 

rev-manifest.json文件內容:

{
  "wap.min.css": "wap.min-c49f62a273.css"
}

 

header.php替換前后對比:

替換前:<link rel="stylesheet" href="/css/wap.min.css" />

替換后:<link rel="stylesheet" href="/css/wap.min-c49f62a273.css" />

gulp-rev-collector進行文件路徑替換是依據 rev-manifest.json 的,所以要先成生 .json 文件,然后再進行替換;

 


免責聲明!

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



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