gulpfile.js 之 優(yōu)化項(xiàng)目總結(jié)

本文所述蔬崩,一個(gè)老舊gulp前端原生項(xiàng)目(html,js,css)的基礎(chǔ)上進(jìn)行改造的隙疚,本文章是在對(duì)改造過(guò)程中各個(gè)階段遇到的問(wèn)題以及解決方式進(jìn)行的一個(gè)總結(jié)。
文檔目錄結(jié)構(gòu)如下:


目錄.png

最初問(wèn)題1

老項(xiàng)目的gulpfile.js 中的build代碼部分是對(duì)src下所有文件的build處理萌衬,最開(kāi)始時(shí)候項(xiàng)目文件較少胰苏,build速度較快,但隨著業(yè)務(wù)擴(kuò)大岸更,項(xiàng)目文件也逐漸增多鸵膏,導(dǎo)致build耗時(shí)越來(lái)越長(zhǎng),平均耗時(shí)3分鐘左右坐慰,嚴(yán)重影響開(kāi)發(fā)效率较性。


old.jpg

解決方法1:

思路: 由于每次build都要遍歷處理所有文件,但是需要處理的真正 改動(dòng)文件 是很少的结胀,所以思路就是赞咙,過(guò)濾掉沒(méi)有變動(dòng)的文件,只處理改動(dòng)的文件糟港。

方法: 使用 gulp-changed 插件攀操,過(guò)濾沒(méi)有變動(dòng)的文件。由于老項(xiàng)目的build代碼任務(wù)入口有很多秸抚,所以需要在所有處理文件的入口處都加入 gulp-changed速和。


new.jpg

原理: 保留原來(lái)build過(guò)程中的 .dist 目錄,作為build代碼的緩存目錄剥汤,每次build會(huì)對(duì)比src與.dist目錄下同名文件的最近修改時(shí)間颠放,只有最新修改時(shí)間晚于上次.dist緩存的文件修改時(shí)間時(shí),才會(huì)通過(guò)管道進(jìn)入到下一個(gè)pipe吭敢。

gulp.src(['./src/**'])
    .pipe(changed(DEST))
    .pipe(gulp.dest(DEST))

解決方法2:

思路:每次build可以指定只build某個(gè)文件夾碰凶。

方法: 使用 node 的環(huán)境變量 process.env.NODE_ENV 傳參給gulp, 每次可以指定需要build的文件夾。build過(guò)程與全局build一樣欲低。

gulp.task("obuild", function(callback) {
  gulp.src(["./src/" + options.env + "/**"])
    .pipe(gulpif(["*.css", '**/*.css'], minifyCss()))
    .pipe(gulpif(["*.js", "**/*.js"], uglify()))
    .pipe(gulp.dest("./.dist/" + options.env ))
only.png

最初問(wèn)題2

不同電腦辕宏,Mac,每次build代碼使用 gulp-rev 添加的hash值會(huì)有所變動(dòng)砾莱,導(dǎo)致變動(dòng)文件過(guò)多瑞筐。

思路:不同電腦,build同一個(gè)文件使用 gulp-rev 添加hash值不同的原因腊瑟,是處理文件的順序不同聚假。

方法: 在處理文件入口處加入 gulp-sort 插件,來(lái)對(duì)內(nèi)存中的文件排序之后再往下pipe扫步,調(diào)用gulp-rev魔策。

gulp.src(['.dist/**/*.*(js|css|jpg|png|webp|gif|jpeg'])
    .pipe( sort() )
    .pipe( rev() )
    .pipe( gulp.dest('dist') )

延伸問(wèn)題

針對(duì)“問(wèn)題1”,添加的兩種方式河胎,全局build 和 單個(gè)文件夾build闯袒,要做到相互不影響。

方法: 全局build游岳,按照原有方案進(jìn)行政敢。單個(gè)build,為了不影響全局build出的dist文件胚迫,需要增加只刪除dist目錄下指定文件夾邏輯喷户。并且生成自己的rev-manifest.json,以替換自己文件夾下文件的hash值访锻,但是為了保證單個(gè)文件夾下也可以引入外部全局下的js或者css文件褪尝,全局生成的rev-manifest.json不能刪除,以保證在build單個(gè)文件夾時(shí)能夠先使用全局生成的json文件替換引用的全局文件期犬。

不足之處

1河哑、對(duì)于問(wèn)題1的第一種方法,使用gulp-changed插件實(shí)則對(duì)比文件的最近修改時(shí)間龟虎,多人協(xié)作開(kāi)發(fā)工程中可能會(huì)出現(xiàn)電腦系統(tǒng)時(shí)間不一致的問(wèn)題璃谨。所以,多人協(xié)作開(kāi)發(fā)前鲤妥,請(qǐng)保證每個(gè)電腦的系統(tǒng)時(shí)間都同步為網(wǎng)絡(luò)時(shí)間佳吞。
2、對(duì)于問(wèn)題2棉安,使用的gulp-sort插件底扳,實(shí)則是當(dāng)gulp任務(wù)開(kāi)始后,排序的是內(nèi)存中的文件贡耽,可能出現(xiàn)windows 與 Mac之間內(nèi)存處理機(jī)制不一致導(dǎo)致hash值不一致的問(wèn)題花盐。所以多人開(kāi)發(fā)時(shí)盡量保證使用同樣的電腦羡滑。

總結(jié):

本次項(xiàng)目?jī)?yōu)化,共有下面幾點(diǎn)成效:

  1. 原本耗時(shí)將近3分鐘的全局build任務(wù)算芯,現(xiàn)在耗時(shí)只為 20s 左右。
  2. 原本多人使用Mac開(kāi)發(fā)凳宙,build代碼生成的文件hash值不同的問(wèn)題熙揍,得到解決。
  3. 增加單個(gè)文件夾文件build任務(wù)氏涩,可以高效提高開(kāi)發(fā)效率届囚。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市是尖,隨后出現(xiàn)的幾起案子意系,更是在濱河造成了極大的恐慌,老刑警劉巖饺汹,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛔添,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡兜辞,警方通過(guò)查閱死者的電腦和手機(jī)迎瞧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)逸吵,“玉大人凶硅,你說(shuō)我怎么就攤上這事∩ㄖ澹” “怎么了足绅?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)韩脑。 經(jīng)常有香客問(wèn)我氢妈,道長(zhǎng),這世上最難降的妖魔是什么扰才? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任允懂,我火速辦了婚禮,結(jié)果婚禮上衩匣,老公的妹妹穿的比我還像新娘蕾总。我一直安慰自己,他們只是感情好琅捏,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布生百。 她就那樣靜靜地躺著,像睡著了一般柄延。 火紅的嫁衣襯著肌膚如雪蚀浆。 梳的紋絲不亂的頭發(fā)上缀程,一...
    開(kāi)封第一講書(shū)人閱讀 51,488評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音市俊,去河邊找鬼杨凑。 笑死,一個(gè)胖子當(dāng)著我的面吹牛摆昧,可吹牛的內(nèi)容都是我干的撩满。 我是一名探鬼主播,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼绅你,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼伺帘!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起忌锯,我...
    開(kāi)封第一講書(shū)人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤伪嫁,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后偶垮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體张咳,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年针史,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了晶伦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡啄枕,死狀恐怖婚陪,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情频祝,我是刑警寧澤泌参,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站常空,受9級(jí)特大地震影響沽一,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜漓糙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一铣缠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧昆禽,春花似錦蝗蛙、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至盗棵,卻和暖如春壮韭,著一層夾襖步出監(jiān)牢的瞬間北发,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工喷屋, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留琳拨,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓屯曹,卻偏偏與公主長(zhǎng)得像从绘,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子是牢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

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