前端構(gòu)建工具gulpjs的使用介紹及技巧

gulpjs是一個(gè)前端構(gòu)建工具危喉,與gruntjs相比钻趋,gulpjs無需寫一大堆繁雜的配置參數(shù),API也非常簡單毁靶,學(xué)習(xí)起來很容易胧奔,而且gulpjs使用的是nodejs中stream來讀取和操作數(shù)據(jù),其速度更快预吆。如果你還沒有使用過前端構(gòu)建工具龙填,或者覺得gruntjs太難用的話,那就嘗試一下gulp吧拐叉。

本文導(dǎo)航:

gulp的安裝

開始使用gulp

gulp的API介紹

一些常用的gulp插件

1岩遗、gulp的安裝

首先確保你已經(jīng)正確安裝了nodejs環(huán)境。然后以全局方式安裝gulp:

npm install -g gulp

全局安裝gulp后凤瘦,還需要在每個(gè)要使用gulp的項(xiàng)目中都單獨(dú)安裝一次宿礁。把目錄切換到你的項(xiàng)目文件夾中,然后在命令行中執(zhí)行:

npm install gulp

如果想在安裝的時(shí)候把gulp寫進(jìn)項(xiàng)目package.json文件的依賴中蔬芥,則可以加上--save-dev:

npm install --save-dev gulp

這樣就完成了gulp的安裝梆靖。至于為什么在全局安裝gulp后,還需要在項(xiàng)目中本地安裝一次???笔诵,有興趣的可以看下stackoverflow上有人做出的回答:why-do-we-need-to-install-gulp-globally-and-locally返吻、what-is-the-point-of-double-install-in-gulp。大體就是為了版本的靈活性乎婿,但如果沒理解那也不必太去糾結(jié)這個(gè)問題测僵,只需要知道通常我們是要這樣做就行了。

2谢翎、開始使用gulp

2.1 建立gulpfile.js文件

就像gruntjs需要一個(gè)Gruntfile.js文件一樣捍靠,gulp也需要一個(gè)文件作為它的主文件,在gulp中這個(gè)文件叫做gulpfile.js岳服。新建一個(gè)文件名為gulpfile.js的文件剂公,然后放到你的項(xiàng)目目錄中。之后要做的事情就是在gulpfile.js文件中定義我們的任務(wù)了吊宋。下面是一個(gè)最簡單的gulpfile.js文件內(nèi)容示例纲辽,它定義了一個(gè)默認(rèn)的任務(wù)颜武。

vargulp=require('gulp');

gulp.task('default',function(){

console.log('hello world');

});

此時(shí)我們的目錄結(jié)構(gòu)是這樣子的:

├── gulpfile.js

├── node_modules

│ └── gulp

└── package.json

2.2 運(yùn)行g(shù)ulp任務(wù)

要運(yùn)行g(shù)ulp任務(wù),只需切換到存放gulpfile.js文件的目錄(windows平臺(tái)請使用cmd或者Power Shell等工具)拖吼,然后在命令行中執(zhí)行g(shù)ulp命令就行了鳞上,gulp后面可以加上要執(zhí)行的任務(wù)名,例如gulp task1吊档,如果沒有指定任務(wù)名篙议,則會(huì)執(zhí)行任務(wù)名為default的默認(rèn)任務(wù)。

3怠硼、gulp的API介紹

使用gulp鬼贱,僅需知道4個(gè)API即可:gulp.task(),gulp.src(),gulp.dest(),gulp.watch(),所以很容易就能掌握香璃,但有幾個(gè)地方需理解透徹才行这难,我會(huì)在下面一一說明。為了避免出現(xiàn)理解偏差葡秒,建議先看一遍官方文檔姻乓。

3.1 gulp.src()

在介紹這個(gè)API之前我們首先來說一下Grunt.js和Gulp.js工作方式的一個(gè)區(qū)別。Grunt主要是以文件為媒介來運(yùn)行它的工作流的眯牧,比如在Grunt中執(zhí)行完一項(xiàng)任務(wù)后蹋岩,會(huì)把結(jié)果寫入到一個(gè)臨時(shí)文件中,然后可以在這個(gè)臨時(shí)文件內(nèi)容的基礎(chǔ)上執(zhí)行其它任務(wù)学少,執(zhí)行完成后又把結(jié)果寫入到臨時(shí)文件中剪个,然后又以這個(gè)為基礎(chǔ)繼續(xù)執(zhí)行其它任務(wù)...就這樣反復(fù)下去。而在Gulp中版确,使用的是Nodejs中的stream(流)禁偎,首先獲取到需要的stream,然后可以通過stream的pipe()方法把流導(dǎo)入到你想要的地方阀坏,比如Gulp的插件中,經(jīng)過插件處理后的流又可以繼續(xù)導(dǎo)入到其他插件中笆檀,當(dāng)然也可以把流寫入到文件中忌堂。所以Gulp是以stream為媒介的,它不需要頻繁的生成臨時(shí)文件酗洒,這也是Gulp的速度比Grunt快的一個(gè)原因士修。再回到正題上來,gulp.src()方法正是用來獲取流的樱衷,但要注意這個(gè)流里的內(nèi)容不是原始的文件流棋嘲,而是一個(gè)虛擬文件對象流(Vinyl files),這個(gè)虛擬文件對象中存儲(chǔ)著原始文件的路徑矩桂、文件名沸移、內(nèi)容等信息,這個(gè)我們暫時(shí)不用去深入理解,你只需簡單的理解可以用這個(gè)方法來讀取你需要操作的文件就行了雹锣。其語法為:

gulp.src(globs[, options])

globs參數(shù)是文件匹配模式(類似正則表達(dá)式)网沾,用來匹配文件路徑(包括文件名),當(dāng)然這里也可以直接指定某個(gè)具體的文件路徑蕊爵。當(dāng)有多個(gè)匹配模式時(shí)辉哥,該參數(shù)可以為一個(gè)數(shù)組。

options為可選參數(shù)攒射。通常情況下我們不需要用到醋旦。

例如:gulp.src('./static/*.js')?或者gulp.src('./static/common.js')

下面我們重點(diǎn)說說Gulp用到的glob的匹配規(guī)則以及一些文件匹配技巧。

Gulp內(nèi)部使用了node-glob模塊來實(shí)現(xiàn)其文件匹配功能会放。我們可以使用下面這些特殊的字符來匹配我們想要的文件:

*匹配文件路徑中的0個(gè)或多個(gè)字符饲齐,但不會(huì)匹配路徑分隔符,除非路徑分隔符出現(xiàn)在末尾

**匹配路徑中的0個(gè)或多個(gè)目錄及其子目錄,需要單獨(dú)出現(xiàn)鸦概,即它左右不能有其他東西了箩张。如果出現(xiàn)在末尾,也能匹配文件窗市。

?匹配文件路徑中的一個(gè)字符(不會(huì)匹配路徑分隔符)

[...]匹配方括號中出現(xiàn)的字符中的任意一個(gè)先慷,當(dāng)方括號中第一個(gè)字符為^或!時(shí),則表示不匹配方括號中出現(xiàn)的其他字符中的任意一個(gè)咨察,類似js正則表達(dá)式中的用法

!(pattern|pattern|pattern)匹配任何與括號中給定的任一模式都不匹配的

?(pattern|pattern|pattern)匹配括號中給定的任一模式0次或1次论熙,類似于js正則中的(pattern|pattern|pattern)?

+(pattern|pattern|pattern)匹配括號中給定的任一模式至少1次,類似于js正則中的(pattern|pattern|pattern)+

*(pattern|pattern|pattern)匹配括號中給定的任一模式0次或多次摄狱,類似于js正則中的(pattern|pattern|pattern)*

@(pattern|pattern|pattern)匹配括號中給定的任一模式1次脓诡,類似于js正則中的(pattern|pattern|pattern)

下面以一系列例子來加深理解

*能匹配a.js,x.y,abc,abc/,但不能匹配a/b.js

*.*能匹配a.js,style.css,a.b,x.y

*/*/*.js能匹配a/b/c.js,x/y/z.js,不能匹配a/b.js,a/b/c/d.js

**能匹配abc,a/b.js,a/b/c.js,x/y/z,x/y/z/a.b,能用來匹配所有的目錄和文件

**/*.js能匹配foo.js,a/foo.js,a/b/foo.js,a/b/c/foo.js

a/**/z能匹配a/z,a/b/z,a/b/c/z,a/d/g/h/j/k/z

a/**b/z能匹配a/b/z,a/sb/z,但不能匹配a/x/sb/z,因?yàn)橹挥袉?*單獨(dú)出現(xiàn)才能匹配多級目錄

?.js能匹配a.js,b.js,c.js

a??能匹配a.b,abc,但不能匹配ab/,因?yàn)樗粫?huì)匹配路徑分隔符

[xyz].js只能匹配x.js,y.js,z.js,不會(huì)匹配xy.js,xyz.js等,整個(gè)中括號只代表一個(gè)字符

[^xyz].js能匹配a.js,b.js,c.js等,不能匹配x.js,y.js,z.js

當(dāng)有多種匹配模式時(shí)可以使用數(shù)組

//使用數(shù)組的方式來匹配多種文件gulp.src(['js/*.js','css/*.css','*.html'])

*使用數(shù)組的方式還有一個(gè)好處就是可以很方便的使用排除模式,在數(shù)組中的單個(gè)匹配模式前加上!即是排除模式媒役,它會(huì)在匹配的結(jié)果中排除這個(gè)匹配祝谚,要注意一點(diǎn)的是不能在數(shù)組中的第一個(gè)元素中使用排除模式

gulp.src([*.js,'!b*.js'])//匹配所有js文件,但排除掉以b開頭的js文件

gulp.src(['!b*.js',*.js])//不會(huì)排除任何文件酣衷,因?yàn)榕懦J讲荒艹霈F(xiàn)在數(shù)組的第一個(gè)元素中

此外交惯,還可以使用展開模式。展開模式以花括號作為定界符穿仪,根據(jù)它里面的內(nèi)容席爽,會(huì)展開為多個(gè)模式,最后匹配的結(jié)果為所有展開的模式相加起來得到的結(jié)果啊片。展開的例子如下:

a{b,c}d會(huì)展開為abd,acd

a{b,}c會(huì)展開為abc,ac

a{0..3}d會(huì)展開為a0d,a1d,a2d,a3d

a{b,c{d,e}f}g會(huì)展開為abg,acdfg,acefg

a{b,c}d{e,f}g會(huì)展開為abdeg,acdeg,abdeg,abdfg

3.2 gulp.dest()

gulp.dest()方法是用來寫文件的只锻,其語法為:

gulp.dest(path[,options])

path為寫入文件的路徑

options為一個(gè)可選的參數(shù)對象,通常我們不需要用到

要想使用好gulp.dest()這個(gè)方法紫谷,就要理解給它傳入的路徑參數(shù)與最終生成的文件的關(guān)系齐饮。

gulp的使用流程一般是這樣子的:首先通過gulp.src()方法獲取到我們想要處理的文件流捐寥,然后把文件流通過pipe方法導(dǎo)入到gulp的插件中,最后把經(jīng)過插件處理后的流再通過pipe方法導(dǎo)入到gulp.dest()中沈矿,gulp.dest()方法則把流中的內(nèi)容寫入到文件中上真,這里首先需要弄清楚的一點(diǎn)是,我們給gulp.dest()傳入的路徑參數(shù)羹膳,只能用來指定要生成的文件的目錄睡互,而不能指定生成文件的文件名,它生成文件的文件名使用的是導(dǎo)入到它的文件流自身的文件名陵像,所以生成的文件名是由導(dǎo)入到它的文件流決定的就珠,即使我們給它傳入一個(gè)帶有文件名的路徑參數(shù),然后它也會(huì)把這個(gè)文件名當(dāng)做是目錄名醒颖,例如:

vargulp =require('gulp');

gulp.src('script/jquery.js')

.pipe(gulp.dest('dist/foo.js'));//最終生成的文件路徑為 dist/foo.js/jquery.js,而不是dist/foo.js

要想改變文件名妻怎,可以使用插件gulp-rename

下面說說生成的文件路徑與我們給gulp.dest()方法傳入的路徑參數(shù)之間的關(guān)系。

gulp.dest(path)生成的文件路徑是我們傳入的path參數(shù)后面再加上gulp.src()中有通配符開始出現(xiàn)的那部分路徑泞歉。例如:

vargulp = reruire('gulp');//有通配符開始出現(xiàn)的那部分路徑為 **/*.jsgulp.src('script/**/*.js') .pipe(gulp.dest('dist'));//最后生成的文件路徑為 dist/**/*.js//如果 **/*.js 匹配到的文件為 jquery/jquery.js ,則生成的文件路徑為 dist/jquery/jquery.js

再舉更多一點(diǎn)的例子

gulp.src('script/avalon/avalon.js')//沒有通配符出現(xiàn)的情況.pipe(gulp.dest('dist'));//最后生成的文件路徑為 dist/avalon.js//有通配符開始出現(xiàn)的那部分路徑為 **/underscore.jsgulp.src('script/**/underscore.js')//假設(shè)匹配到的文件為script/util/underscore.js.pipe(gulp.dest('dist'));//則最后生成的文件路徑為 dist/util/underscore.jsgulp.src('script/*')//有通配符出現(xiàn)的那部分路徑為 *//假設(shè)匹配到的文件為script/zepto.js.pipe(gulp.dest('dist'));//則最后生成的文件路徑為 dist/zepto.js

通過指定gulp.src()方法配置參數(shù)中的base屬性逼侦,我們可以更靈活的來改變gulp.dest()生成的文件路徑。

當(dāng)我們沒有在gulp.src()方法中配置base屬性時(shí)腰耙,base的默認(rèn)值為通配符開始出現(xiàn)之前那部分路徑榛丢,例如:

gulp.src('app/src/**/*.css')//此時(shí)base的值為 app/src

上面我們說的gulp.dest()所生成的文件路徑的規(guī)則,其實(shí)也可以理解成挺庞,用我們給gulp.dest()傳入的路徑替換掉gulp.src()中的base路徑晰赞,最終得到生成文件的路徑。

gulp.src('app/src/**/*.css') //此時(shí)base的值為app/src,也就是說它的base路徑為app/src //設(shè)該模式匹配到了文件 app/src/css/normal.css .pipe(gulp.dest('dist')) //用dist替換掉base路徑选侨,最終得到 dist/css/normal.css

所以改變base路徑后掖鱼,gulp.dest()生成的文件路徑也會(huì)改變

gulp.src(script/lib/*.js)//沒有配置base參數(shù),此時(shí)默認(rèn)的base路徑為script/lib//假設(shè)匹配到的文件為script/lib/jquery.js .pipe(gulp.dest('build'))//生成的文件路徑為 build/jquery.jsgulp.src(script/lib/*.js, {base:'script'})//配置了base參數(shù)援制,此時(shí)base路徑為script//假設(shè)匹配到的文件為script/lib/jquery.js .pipe(gulp.dest('build'))//此時(shí)生成的文件路徑為 build/lib/jquery.js

用gulp.dest()把文件流寫入文件后戏挡,文件流仍然可以繼續(xù)使用。

3.3 gulp.task()

gulp.task方法用來定義任務(wù)晨仑,內(nèi)部使用的是Orchestrator增拥,其語法為:

gulp.task(name[, deps],fn)

name為任務(wù)名

deps是當(dāng)前定義的任務(wù)需要依賴的其他任務(wù),為一個(gè)數(shù)組寻歧。當(dāng)前定義的任務(wù)會(huì)在所有依賴的任務(wù)執(zhí)行完畢后才開始執(zhí)行。如果沒有依賴秩仆,則可省略這個(gè)參數(shù)

fn為任務(wù)函數(shù)码泛,我們把任務(wù)要執(zhí)行的代碼都寫在里面。該參數(shù)也是可選的澄耍。

gulp.task('mytask', ['array','of','task','names'],function(){//定義一個(gè)有依賴的任務(wù)// Do something});

gulp.task()這個(gè)API沒什么好講的噪珊,但需要知道執(zhí)行多個(gè)任務(wù)時(shí)怎么來控制任務(wù)執(zhí)行的順序晌缘。

gulp中執(zhí)行多個(gè)任務(wù),可以通過任務(wù)依賴來實(shí)現(xiàn)痢站。例如我想要執(zhí)行one,two,three這三個(gè)任務(wù)磷箕,那我們就可以定義一個(gè)空的任務(wù),然后把那三個(gè)任務(wù)當(dāng)做這個(gè)空的任務(wù)的依賴就行了:

//只要執(zhí)行default任務(wù)阵难,就相當(dāng)于把one,two,three這三個(gè)任務(wù)執(zhí)行了gulp.task('default',['one','two','three']);

如果任務(wù)相互之間沒有依賴岳枷,任務(wù)會(huì)按你書寫的順序來執(zhí)行,如果有依賴的話則會(huì)先執(zhí)行依賴的任務(wù)呜叫。

但是如果某個(gè)任務(wù)所依賴的任務(wù)是異步的空繁,就要注意了,gulp并不會(huì)等待那個(gè)所依賴的異步任務(wù)完成朱庆,而是會(huì)接著執(zhí)行后續(xù)的任務(wù)盛泡。例如:

gulp.task('one',function(){//one是一個(gè)異步執(zhí)行的任務(wù)setTimeout(function(){console.log('one is done') },5000);});//two任務(wù)雖然依賴于one任務(wù),但并不會(huì)等到one任務(wù)中的異步操作完成后再執(zhí)行g(shù)ulp.task('two',['one'],function(){console.log('two is done');});

上面的例子中我們執(zhí)行two任務(wù)時(shí),會(huì)先執(zhí)行one任務(wù)娱颊,但不會(huì)去等待one任務(wù)中的異步操作完成后再執(zhí)行two任務(wù)傲诵,而是緊接著執(zhí)行two任務(wù)。所以two任務(wù)會(huì)在one任務(wù)中的異步操作完成之前就執(zhí)行了箱硕。

那如果我們想等待異步任務(wù)中的異步操作完成后再執(zhí)行后續(xù)的任務(wù)拴竹,該怎么做呢?

有三種方法可以實(shí)現(xiàn):

第一:在異步操作完成后執(zhí)行一個(gè)回調(diào)函數(shù)來通知gulp這個(gè)異步任務(wù)已經(jīng)完成,這個(gè)回調(diào)函數(shù)就是任務(wù)函數(shù)的第一個(gè)參數(shù)颅痊。

gulp.task('one',function(cb){//cb為任務(wù)函數(shù)提供的回調(diào)殖熟,用來通知任務(wù)已經(jīng)完成//one是一個(gè)異步執(zhí)行的任務(wù)setTimeout(function(){console.log('one is done'); cb();//執(zhí)行回調(diào),表示這個(gè)異步任務(wù)已經(jīng)完成},5000);});//這時(shí)two任務(wù)會(huì)在one任務(wù)中的異步操作完成后再執(zhí)行g(shù)ulp.task('two',['one'],function(){console.log('two is done');});

第二:定義任務(wù)時(shí)返回一個(gè)流對象斑响。適用于任務(wù)就是操作gulp.src獲取到的流的情況菱属。

gulp.task('one',function(cb){varstream = gulp.src('client/**/*.js') .pipe(dosomething())//dosomething()中有某些異步操作.pipe(gulp.dest('build'));returnstream;});gulp.task('two',['one'],function(){console.log('two is done');});

第三:返回一個(gè)promise對象,例如

varQ =require('q');//一個(gè)著名的異步處理的庫https://github.com/kriskowal/qgulp.task('one',function(cb){vardeferred = Q.defer();// 做一些異步操作setTimeout(function(){ deferred.resolve(); },5000);returndeferred.promise;});gulp.task('two',['one'],function(){console.log('two is done');});

gulp.task()就這些了舰罚,主要是要知道當(dāng)依賴是異步任務(wù)時(shí)的處理纽门。

3.4 gulp.watch()

gulp.watch()用來監(jiān)視文件的變化,當(dāng)文件發(fā)生變化后营罢,我們可以利用它來執(zhí)行相應(yīng)的任務(wù)赏陵,例如文件壓縮等。其語法為

gulp.watch(glob[, opts],tasks)

glob為要監(jiān)視的文件匹配模式饲漾,規(guī)則和用法與gulp.src()方法中的glob相同蝙搔。

opts為一個(gè)可選的配置對象,通常不需要用到

tasks為文件變化后要執(zhí)行的任務(wù)考传,為一個(gè)數(shù)組

gulp.task('uglify',function(){//do something});gulp.task('reload',function(){//do something});gulp.watch('js/**/*.js', ['uglify','reload']);

gulp.watch()還有另外一種使用方式:

gulp.watch(glob[, opts, cb])

globopts參數(shù)與第一種用法相同

cb參數(shù)為一個(gè)函數(shù)吃型。每當(dāng)監(jiān)視的文件發(fā)生變化時(shí),就會(huì)調(diào)用這個(gè)函數(shù),并且會(huì)給它傳入一個(gè)對象僚楞,該對象包含了文件變化的一些信息勤晚,type屬性為變化的類型枉层,可以是added,changed,deleted;path屬性為發(fā)生變化的文件的路徑

gulp.watch('js/**/*.js',function(event){console.log(event.type);//變化類型 added為新增,deleted為刪除赐写,changed為改變console.log(event.path);//變化的文件的路徑});

4鸟蜡、一些常用的gulp插件

gulp的插件數(shù)量雖然沒有g(shù)runt那么多,但也可以說是應(yīng)有盡有了挺邀,下面列舉一些常用的插件揉忘。

4.1 自動(dòng)加載插件

使用gulp-load-plugins

安裝:npm install --save-dev gulp-load-plugins

要使用gulp的插件,首先得用require來把插件加載進(jìn)來悠夯,如果我們要使用的插件非常多癌淮,那我們的gulpfile.js文件開頭可能就會(huì)是這個(gè)樣子的:

vargulp =require('gulp'),//一些gulp插件,abcd這些命名只是用來舉個(gè)例子a =require('gulp-a'), b =require('gulp-b'), c =require('gulp-c'), d =require('gulp-d'), e =require('gulp-e'), f =require('gulp-f'), g =require('gulp-g'),//更多的插件...z =require('gulp-z');

雖然這沒什么問題,但會(huì)使我們的gulpfile.js文件變得很冗長沦补,看上去不那么舒服乳蓄。gulp-load-plugins插件正是用來解決這個(gè)問題。

gulp-load-plugins這個(gè)插件能自動(dòng)幫你加載package.json文件里的gulp插件夕膀。例如假設(shè)你的package.json文件里的依賴是這樣的:

{ "devDependencies": { "gulp":"~3.6.0", "gulp-rename":"~1.2.0", "gulp-ruby-sass":"~0.4.3", "gulp-load-plugins":"~0.5.1"}}

然后我們可以在gulpfile.js中使用gulp-load-plugins來幫我們加載插件:

vargulp =require('gulp');//加載gulp-load-plugins插件虚倒,并馬上運(yùn)行它varplugins =require('gulp-load-plugins')();

然后我們要使用gulp-rename和gulp-ruby-sass這兩個(gè)插件的時(shí)候,就可以使用plugins.rename和plugins.rubySass來代替了,也就是原始插件名去掉gulp-前綴产舞,之后再轉(zhuǎn)換為駝峰命名魂奥。

實(shí)質(zhì)上gulp-load-plugins是為我們做了如下的轉(zhuǎn)換

plugins.rename=require('gulp-rename');plugins.rubySass =require('gulp-ruby-sass');

gulp-load-plugins并不會(huì)一開始就加載所有package.json里的gulp插件,而是在我們需要用到某個(gè)插件的時(shí)候易猫,才去加載那個(gè)插件耻煤。

最后要提醒的一點(diǎn)是,因?yàn)間ulp-load-plugins是通過你的package.json文件來加載插件的准颓,所以必須要保證你需要自動(dòng)加載的插件已經(jīng)寫入到了package.json文件里哈蝇,并且這些插件都是已經(jīng)安裝好了的。

4.2 重命名

使用gulp-rename

安裝:npm install --save-dev gulp-rename

用來重命名文件流中的文件攘已。用gulp.dest()方法寫入文件時(shí)炮赦,文件名使用的是文件流中的文件名,如果要想改變文件名样勃,那可以在之前用gulp-rename插件來改變文件流中的文件名吠勘。

var gulp =require('gulp'),rename=require('gulp-rename'), uglify =require("gulp-uglify"); gulp.task('rename', function () { gulp.src('js/jquery.js') .pipe(uglify()) //壓縮 .pipe(rename('jquery.min.js')) //會(huì)將jquery.js重命名為jquery.min.js .pipe(gulp.dest('js'));//關(guān)于gulp-rename的更多強(qiáng)大的用法請參考https://www.npmjs.com/package/gulp-rename});

4.3 js文件壓縮

使用gulp-uglify

安裝:npm install --save-dev gulp-uglify

用來壓縮js文件,使用的是uglify引擎

vargulp =require('gulp'), uglify =require("gulp-uglify"); gulp.task('minify-js',function(){ gulp.src('js/*.js')// 要壓縮的js文件.pipe(uglify())//使用uglify進(jìn)行壓縮,更多配置請參考:.pipe(gulp.dest('dist/js'));//壓縮后的路徑});

4.4 css文件壓縮

使用gulp-minify-css

安裝:npm install --save-dev gulp-minify-css

要壓縮css文件時(shí)可以使用該插件

vargulp =require('gulp'), minifyCss =require("gulp-minify-css"); gulp.task('minify-css',function(){ gulp.src('css/*.css')// 要壓縮的css文件.pipe(minifyCss())//壓縮css.pipe(gulp.dest('dist/css'));});

4.5 html文件壓縮

使用gulp-minify-html

安裝:npm install --save-dev gulp-minify-html

用來壓縮html文件

vargulp =require('gulp'), minifyHtml =require("gulp-minify-html"); gulp.task('minify-html',function(){ gulp.src('html/*.html')// 要壓縮的html文件.pipe(minifyHtml())//壓縮.pipe(gulp.dest('dist/html'));});

4.6 js代碼檢查

使用gulp-jshint

安裝:npm install --save-dev gulp-jshint

用來檢查js代碼

vargulp =require('gulp'), jshint =require("gulp-jshint"); gulp.task('jsLint',function(){ gulp.src('js/*.js') .pipe(jshint()) .pipe(jshint.reporter());// 輸出檢查結(jié)果});

4.7 文件合并

使用gulp-concat

安裝:npm install --save-dev gulp-concat

用來把多個(gè)文件合并為一個(gè)文件,我們可以用它來合并js或css文件等峡眶,這樣就能減少頁面的http請求數(shù)了

vargulp =require('gulp'), concat =require("gulp-concat"); gulp.task('concat',function(){ gulp.src('js/*.js')//要合并的文件.pipe(concat('all.js'))// 合并匹配到的js文件并命名為 "all.js".pipe(gulp.dest('dist/js'));});

4.8 less和sass的編譯

less使用gulp-less,安裝:npm install --save-dev gulp-less

vargulp =require('gulp'), less =require("gulp-less"); gulp.task('compile-less',function(){ gulp.src('less/*.less') .pipe(less()) .pipe(gulp.dest('dist/css'));});

sass使用gulp-sass,安裝:npm install --save-dev gulp-sass

vargulp =require('gulp'), sass =require("gulp-sass"); gulp.task('compile-sass',function(){ gulp.src('sass/*.sass') .pipe(sass()) .pipe(gulp.dest('dist/css'));});

4.9 圖片壓縮

可以使用gulp-imagemin插件來壓縮jpg剧防、png、gif等圖片辫樱。

安裝:npm install --save-dev gulp-imagemin

vargulp =require('gulp');varimagemin =require('gulp-imagemin');varpngquant =require('imagemin-pngquant');//png圖片壓縮插件gulp.task('default',function(){returngulp.src('src/images/*') .pipe(imagemin({ progressive:true, use: [pngquant()]//使用pngquant來壓縮png圖片})) .pipe(gulp.dest('dist'));});

gulp-imagemin的使用比較復(fù)雜一點(diǎn)峭拘,而且它本身也有很多插件,建議去它的項(xiàng)目主頁看看文檔

4.10 自動(dòng)刷新

使用gulp-livereload插件,安裝:npm install --save-dev gulp-livereload棚唆。

當(dāng)代碼變化時(shí),它可以幫我們自動(dòng)刷新頁面

該插件最好配合谷歌瀏覽器來使用心例,且要安裝livereload chrome extension擴(kuò)展插件,不能下載的請自行FQ宵凌。

vargulp =require('gulp'), less =require('gulp-less'), livereload =require('gulp-livereload');gulp.task('less',function(){ gulp.src('less/*.less') .pipe(less()) .pipe(gulp.dest('css')) .pipe(livereload());});gulp.task('watch',function(){ livereload.listen();//要在這里調(diào)用listen()方法gulp.watch('less/*.less', ['less']);});

如對gulp還有什么不明白之處,或者本文有什么遺漏或錯(cuò)誤止后,歡迎一起交流和探討~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瞎惫,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子译株,更是在濱河造成了極大的恐慌瓜喇,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件歉糜,死亡現(xiàn)場離奇詭異乘寒,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)匪补,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進(jìn)店門伞辛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人夯缺,你說我怎么就攤上這事蚤氏。” “怎么了踊兜?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵竿滨,是天一觀的道長。 經(jīng)常有香客問我捏境,道長于游,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任典蝌,我火速辦了婚禮曙砂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘骏掀。我一直安慰自己鸠澈,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布截驮。 她就那樣靜靜地躺著笑陈,像睡著了一般。 火紅的嫁衣襯著肌膚如雪葵袭。 梳的紋絲不亂的頭發(fā)上涵妥,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天,我揣著相機(jī)與錄音坡锡,去河邊找鬼蓬网。 笑死窒所,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的帆锋。 我是一名探鬼主播吵取,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼锯厢!你這毒婦竟也來了皮官?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤实辑,失蹤者是張志新(化名)和其女友劉穎捺氢,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體剪撬,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡摄乒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了婿奔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缺狠。...
    茶點(diǎn)故事閱讀 40,030評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖萍摊,靈堂內(nèi)的尸體忽然破棺而出挤茄,到底是詐尸還是另有隱情,我是刑警寧澤冰木,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布穷劈,位于F島的核電站,受9級特大地震影響踊沸,放射性物質(zhì)發(fā)生泄漏歇终。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一逼龟、第九天 我趴在偏房一處隱蔽的房頂上張望评凝。 院中可真熱鬧,春花似錦腺律、人聲如沸奕短。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽翎碑。三九已至,卻和暖如春之斯,著一層夾襖步出監(jiān)牢的瞬間日杈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留莉擒,地道東北人酿炸。 一個(gè)月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像涨冀,于是被迫代替她去往敵國和親梁沧。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評論 2 355

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

  • gulpjs是一個(gè)前端構(gòu)建工具蝇裤,與gruntjs相比,gulpjs無需寫一大堆繁雜的配置參數(shù)频鉴,API也非常簡單栓辜,學(xué)...
    井皮皮閱讀 1,298評論 0 10
  • gulpjs是一個(gè)前端構(gòu)建工具,與gruntjs相比垛孔,gulpjs無需寫一大堆繁雜的配置參數(shù)藕甩,API也非常簡單,學(xué)...
    依依玖玥閱讀 3,155評論 7 55
  • 前言 本文默認(rèn)你已經(jīng)安裝好node環(huán)境周荐,并且熟悉node命令狭莱,和window cd命令。 gulp簡介 基于nod...
    9I閱讀 1,985評論 4 50
  • gulpjs是一個(gè)前端構(gòu)建工具概作,與gruntjs相比腋妙,gulpjs無需寫一大堆繁雜的配置參數(shù),API也非常簡單讯榕,學(xué)...
    build1024閱讀 529評論 0 0
  • 1骤素、gulp的安裝 首先確保你已經(jīng)正確安裝了nodejs環(huán)境。然后以全局方式安裝gulp: npm install...
    F_imok閱讀 2,378評論 1 11