gulp學(xué)習(xí)點(diǎn)滴


項(xiàng)目目錄

現(xiàn)在要對(duì)當(dāng)前的項(xiàng)目進(jìn)行壓縮,對(duì)里面的樣式,圖片眉睹,腳本留潦,靜態(tài)頁面進(jìn)行壓縮
在網(wǎng)上找了找看有沒有現(xiàn)成的工具使用
因?yàn)轫?xiàng)目用的是seajs,所以想找一個(gè)能對(duì)模塊合并的方法辣往,但是目前還沒有合適的方法兔院,網(wǎng)上的方法 gulp-seajs-combo gulp-alias-combo ,對(duì)我有配置的sea.config都沒有很好的支持站削,所以我放棄了坊萝,還是先壓縮再考慮合并問題,花了幾天的時(shí)間先了解nodejs,gulp
百度许起,google了一堆教程十偶,先安裝了nodejs, gulp gulp插件集錦
用的是visual studio code開發(fā)
先把工具配好,參考 Visual Studio Code 使用 Typings 實(shí)現(xiàn)智能提示功能

//在你的項(xiàng)目根目錄下創(chuàng)建gulpfile.js园细,代碼如下:
/// <reference path="./typings/main.d.ts" />
// 引入 gulp
var gulp = require('gulp');
// 引入組件
var changed = require('gulp-changed');  
var debug = require('gulp-debug');
var del = require('del'); //刪除文件
var watch = require('gulp-watch');//監(jiān)控文件變化
var batch = require('gulp-batch');
var vinylPaths = require('vinyl-paths');//虛擬管道
var filter = require('gulp-filter'); //文件過濾
var livereload = require('gulp-livereload');
var newer = require('gulp-newer');
var htmlmin = require('gulp-htmlmin'), //html壓縮
    imagemin = require('gulp-imagemin'),//圖片壓縮
    pngcrush = require('imagemin-pngcrush'),
    minifycss = require('gulp-minify-css'),//css壓縮
    jshint = require('gulp-jshint'),//js檢測(cè)
    uglify = require('gulp-uglify'),//js壓縮
    UglifyJS = require('uglify-js'), //JS壓縮
    concat = require('gulp-concat'),//文件合并
    rename = require('gulp-rename'),//文件更名  
    through = require("through2"),
    plumber = require('gulp-plumber');

圖片壓縮任務(wù)

gulp.task('buildimg', function() {
    return gulp.src('./{distributor,consumer,retailer}/image/*.{png,jpg}', { base: './' })    
        .pipe(changed('build'))   
        .pipe(debug({title: '編譯:'}))
        .pipe(imagemin({
            progressive: true,
            svgoPlugins: [{removeViewBox: false}],
            use: [pngcrush()]
        }))
        .pipe(gulp.dest('build'));
});

樣式任務(wù)

gulp.task('buildCss', function() {
    return gulp.src('./{distributor,consumer,retailer}/css/*.css', { base: './' })
        .pipe(debug({title: '編譯:'}))
        .pipe(minifycss())
        .pipe(gulp.dest('build'));
});

腳本任務(wù)

gulp.task('buildjs', function() {
     return gulp.src(['./{distributor,consumer,retailer}/js/*.js',
                      './js/*.js',
                      './js/jquery/1.11.3/*.js',                      
                      './js/{jquery,seajs}/*.js',
                      '!./{distributor,consumer,retailer}/js/jquery-*.js'], { base: './' })
        .pipe(changed('build'))
        .pipe(debug({title: '編譯:'}))
        // .pipe(concat('all.js'))
        // .pipe(gulp.dest('dest/js'))
        // .pipe(rename({ suffix: '.min' }))
        .pipe(uglify({
            //mangle: true,//類型:Boolean 默認(rèn):true 是否修改變量名
            mangle: {except: ['require' ,'exports' ,'module' ,'$','wx','wxjsconfig']}//排除混淆關(guān)鍵字
        }))
        .pipe(gulp.dest('build'));
});

html

gulp.task('buildhtml', function () {
      
  return gulp
    .src('./{distributor,consumer,retailer}/page/*.html',{ base: './' })
    .pipe(changed('build'))
    .pipe(debug({title: '編譯:'}))
    .pipe(through.obj(function(file, encode, cb) {
    var contents = file.contents.toString(encode);       
        var HTMLMinifier = require("html-minifier").minify; //壓縮
        var minified = HTMLMinifier(contents, {
          minifyCSS: true,
          minifyJS: true,
          collapseWhitespace: true,
          removeAttributeQuotes: true
        });
        file.contents = new Buffer(minified, encode);
        cb(null, file, encode);     
    }))
    .pipe(gulp.dest('build'));
});

文件監(jiān)控惦积,這個(gè)花的時(shí)間最多,對(duì)文件的新增猛频,刪除狮崩,修改都有及時(shí)的反應(yīng)


function isunlink(file) {    
    return file.event === 'unlink';
}

var filterisunlink = filter(isunlink, {restore: true});

function getfiletype(file)
{
    var filepath = file.path;    
        var index = filepath.lastIndexOf('.');
        var filetype = "";        
        if(index>0)
            filetype = filepath.substring(index,filepath.length);  
    return filetype;
}

function isAdded(file) {  
    
    return file.event === 'add' || file.event === 'change';
}
function ishtml(file)
{
    return getfiletype(file) == ".html";
}
function isjs(file)
{
    return getfiletype(file) == ".js";
}
function isCSS(file)
{
    return getfiletype(file) == ".css";
}
function isImage(file)
{
    return getfiletype(file) == ".jpg" || getfiletype(file) == ".png";
}
var filterAdded = filter(isAdded, {restore: true});

var filterHtml = filter(ishtml,{restore: true});

var filterJs = filter(isjs,{restore: true});

var filterCss = filter(isCSS,{restore: true});

var filterImage = filter(isImage,{restore: true});

gulp.task('buildwatch', function () {    
    return gulp.src('./{distributor,consumer,retailer,js}/**', { base: './' })
        .pipe(watch('./{distributor,consumer,retailer,js}/**'))
        .pipe(filterAdded)
        .pipe(debug({title: '編譯:'}))      
        .pipe(filterHtml)        
        .pipe(through.obj(function(file, encode, cb) {
            var contents = file.contents.toString(encode);       
            var HTMLMinifier = require("html-minifier").minify; //壓縮
            var minified = HTMLMinifier(contents, {
            minifyCSS: true,
            minifyJS: true,
            collapseWhitespace: true,
            removeAttributeQuotes: true
            });
            file.contents = new Buffer(minified, encode);
            cb(null, file, encode);     
        }))
        .pipe(filterHtml.restore)
        .pipe(filterJs)
         .pipe(uglify({
            //mangle: true,//類型:Boolean 默認(rèn):true 是否修改變量名
            mangle: {except: ['require' ,'exports' ,'module' ,'$','wx','wxjsconfig']}//排除混淆關(guān)鍵字
        }))
        .pipe(filterJs.restore)
         .pipe(filterImage)
        .pipe(imagemin({
            progressive: true,
            svgoPlugins: [{removeViewBox: false}],
            use: [pngcrush()]
        }))
        .pipe(filterImage.restore)
        .pipe(filterCss)
        .pipe(minifycss())
        .pipe(filterCss.restore)
        .pipe(gulp.dest('build'))        
        .pipe(filterAdded.restore)       
        .pipe(filterisunlink)          
        .pipe(gulp.dest('build'))
        .pipe(vinylPaths(del))
        .pipe(filterisunlink.restore)
        .pipe(livereload());     
});

之前的版本,對(duì)新增及刪除鹿寻,支持不太好

// gulp.task('watch',function(){
//     // 監(jiān)聽html文件變化    
//     var watcher = gulp.watch('{distributor,consumer,retailer,js}/**');
//     watcher.on('change', function(event) {
//         var filepath =  event.path;
//         var index = filepath.lastIndexOf('.');
//         var filetype = "";
//         console.log('File ' + event.path + ' was ' + event.type + ', running tasks...');
//         if(index>0)
//             filetype = filepath.substring(index,filepath.length);               
//         switch(filetype)
//         {
//             case '.html':
//                 gulp.run('buildhtml');
//             break;
//             case '.js':
//                 gulp.run('buildjs');
//             break;
//             case '.css':
//                 gulp.run('buildCss');
//             break;
//             case '.png':
//             case '.jpg':            
//                 gulp.run('buildimg');
//             break;
//             default:
//             console.log("沒有找到該類型的文件" + filetype);
//         }        
        
//     });
// })

待續(xù) 2015-05-15 19:57
參考&進(jìn)一步閱讀
是時(shí)候擱置Grunt睦柴,耍一耍gulp了
前端打包構(gòu)建工具gulp快速入門
Gulp:插件編寫入門
gulp:更簡(jiǎn)單的自動(dòng)化構(gòu)建工具

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市毡熏,隨后出現(xiàn)的幾起案子坦敌,更是在濱河造成了極大的恐慌,老刑警劉巖痢法,帶你破解...
    沈念sama閱讀 222,627評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件狱窘,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡财搁,警方通過查閱死者的電腦和手機(jī)蘸炸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來妇拯,“玉大人幻馁,你說我怎么就攤上這事≡叫猓” “怎么了仗嗦?”我有些...
    開封第一講書人閱讀 169,346評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長甘凭。 經(jīng)常有香客問我稀拐,道長,這世上最難降的妖魔是什么丹弱? 我笑而不...
    開封第一講書人閱讀 60,097評(píng)論 1 300
  • 正文 為了忘掉前任德撬,我火速辦了婚禮铲咨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蜓洪。我一直安慰自己纤勒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,100評(píng)論 6 398
  • 文/花漫 我一把揭開白布隆檀。 她就那樣靜靜地躺著摇天,像睡著了一般。 火紅的嫁衣襯著肌膚如雪恐仑。 梳的紋絲不亂的頭發(fā)上泉坐,一...
    開封第一講書人閱讀 52,696評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音裳仆,去河邊找鬼腕让。 笑死,一個(gè)胖子當(dāng)著我的面吹牛歧斟,可吹牛的內(nèi)容都是我干的纯丸。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼构捡,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼液南!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起勾徽,我...
    開封第一講書人閱讀 40,108評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎统扳,沒想到半個(gè)月后喘帚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,646評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡咒钟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,709評(píng)論 3 342
  • 正文 我和宋清朗相戀三年吹由,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片朱嘴。...
    茶點(diǎn)故事閱讀 40,861評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡倾鲫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出萍嬉,到底是詐尸還是另有隱情乌昔,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布壤追,位于F島的核電站磕道,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏行冰。R本人自食惡果不足惜溺蕉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,196評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望疯特。 院中可真熱鬧哗魂,春花似錦漓雅、人聲如沸啡彬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吃衅。三九已至往踢,卻和暖如春徘层,著一層夾襖步出監(jiān)牢的瞬間峻呕,已是汗流浹背趣效。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評(píng)論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留跷敬,地道東北人讯私。 一個(gè)月前我還...
    沈念sama閱讀 49,287評(píng)論 3 379
  • 正文 我出身青樓西傀,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拥褂。 傳聞我的和親對(duì)象是個(gè)殘疾皇子娘锁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,860評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • 內(nèi)向與外向的區(qū)分在于獲得能量的方式不一樣饺鹃。內(nèi)向的人獨(dú)處的時(shí)候獲得能量。外向的人從與人交往中獲得能量悔详。 內(nèi)向的人更適...
    chinawzck閱讀 1,090評(píng)論 1 0
  • 2016年的最后一個(gè)晚上,走著走著就走沒了。 最后倒數(shù)五秒鐘是在電影院看著手機(jī)數(shù)的党巾。其實(shí)好像也沒什么意義,時(shí)鐘每天...
    貍貓醬閱讀 147評(píng)論 0 0
  • 最后的最后署海,她將他送到返回的列車上吗购,掛著標(biāo)志性的微笑砸狞,揮手再見捻勉。即使她知道刀森,這一揮手可能就是永遠(yuǎn)的別離了踱启。 我們是...
    密邇兒閱讀 761評(píng)論 6 5
  • 我想生活的魅力就在于此吧:享受生活帶給我們的各種波瀾不驚研底,細(xì)細(xì)品味其中的妙趣橫生埠偿! 學(xué)生姓名:牛少坤 年級(jí):五年...
    小倪老師有話說閱讀 650評(píng)論 3 4