gulp自動化構(gòu)建項目(二)——自動化

第一次接觸自動化構(gòu)建我的表情是這樣的

我們繼續(xù)在跟目錄下創(chuàng)建src / html烙常,dist /html文件夾视粮,,在src/ html下面創(chuàng)建index.html文件安吁,現(xiàn)在的結(jié)構(gòu)應(yīng)該是這樣的:

myweb
    |----- dist
          |-----html
    |----- node_modules
    |-----src
          |-----html
                |-----index.html

現(xiàn)在在index.html文件中寫入<h1>hello world</h1>贺归。

實現(xiàn)自動拷貝

接下來編寫gulpfile.js文件脖咐,這是實現(xiàn)自動化的關(guān)鍵,目的是把src/ html下面的index.html文件拷貝到dist / html

//引入gulp模塊
var gulp = require('gulp');
//創(chuàng)建任務(wù)默终,任務(wù)名為copy
gulp.task('copy',function(){
    //讀取文件
    gulp.src('src/html/index.html')
    //寫入文件
    .pipe(gulp.dest('dist/html'));
});

編寫完成后椅棺,在控制臺用gulp copy執(zhí)行copy任務(wù)

執(zhí)行命令

然后查看dist --> html下面已經(jīng)存在index.html文件。

創(chuàng)建http服務(wù)

下一個任務(wù)是創(chuàng)建一個http服務(wù)齐蔽,通過http服務(wù)訪問dist / html下面的idnex.html两疚。這就需要引入browsersync插件。先用npm安裝含滴,

npm install browser-sync --save-dev

安裝完成后在gulpfile.js中增加以下代碼塊:

//引入browser-sync模塊并創(chuàng)建一個bs對象
var bs = require('browser-sync').create();
//創(chuàng)建server服務(wù),名為start
gulp.task('start',function(){
    bs.init({
        server:'./dist/html/'
    });
});

完成后在控制臺調(diào)用此任務(wù)

調(diào)用http服務(wù)

打開瀏覽器訪問localhost:3000(也可能瀏覽器會自動打開)诱渤,出現(xiàn)Hello World,按ctrl+c關(guān)閉服務(wù)谈况,任務(wù)完成勺美。

多窗口同步

接下來是一個有趣的事,如果上面編寫的index.html足夠長碑韵,在同時打開多個瀏覽器窗口瀏覽的情況下赡茸,所有窗口竟然會同步滾動!如果此時有手機和這臺電腦處于同一個局域網(wǎng)絡(luò)的話祝闻,手機訪問控制臺中External提供的URL打開的窗口會和PC上的保持同步占卧!如下圖所示效果

多窗口同步展示

實現(xiàn)監(jiān)聽

現(xiàn)在的任務(wù)是實現(xiàn)只要src中的源文件index.html有所改動,程序會自動拷貝到dist-->html下面(即執(zhí)行上面編寫的copy任務(wù)),并且瀏覽器自動刷新屉栓,實現(xiàn)實時瀏覽”這里用到了監(jiān)聽事件舷蒲,繼續(xù)編寫start任務(wù):

//引入browser-sync模塊并創(chuàng)建一個bs對象
var bs = require('browser-sync').create();
//創(chuàng)建server服務(wù),名為start
gulp.task('start',function(){
    bs.init({
        server:'./dist/html/'
    });
    gulp.watch('src/html/index.html',['copy']);
    gulp.watch(['src/html/index.html']).on('change',bs.reload);
});

編寫完成后在控制臺執(zhí)行start任務(wù),開啟http服務(wù)友多。打開多個窗口,發(fā)現(xiàn)能實現(xiàn)同步滾動堤框,現(xiàn)在不要關(guān)閉瀏覽器窗口域滥,打開src/html/index.html,修改頁面內(nèi)容蜈抓,發(fā)現(xiàn)多個瀏覽器窗口實時刷新启绰,展示修改后的結(jié)果。

修改實時同步預(yù)覽

到此沟使,初步的自動化已經(jīng)實現(xiàn)了委可,此處實時刷新的效率與電腦配置有關(guān)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末腊嗡,一起剝皮案震驚了整個濱河市着倾,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌燕少,老刑警劉巖卡者,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異客们,居然都是意外死亡崇决,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進店門底挫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來恒傻,“玉大人,你說我怎么就攤上這事建邓∮澹” “怎么了?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵涝缝,是天一觀的道長扑庞。 經(jīng)常有香客問我,道長拒逮,這世上最難降的妖魔是什么罐氨? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮滩援,結(jié)果婚禮上栅隐,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好租悄,可當(dāng)我...
    茶點故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布谨究。 她就那樣靜靜地躺著,像睡著了一般泣棋。 火紅的嫁衣襯著肌膚如雪胶哲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天潭辈,我揣著相機與錄音鸯屿,去河邊找鬼。 笑死把敢,一個胖子當(dāng)著我的面吹牛寄摆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播修赞,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼婶恼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了柏副?” 一聲冷哼從身側(cè)響起勾邦,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎搓扯,沒想到半個月后检痰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡锨推,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年铅歼,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片换可。...
    茶點故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡椎椰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出沾鳄,到底是詐尸還是另有隱情慨飘,我是刑警寧澤,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布译荞,位于F島的核電站瓤的,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏吞歼。R本人自食惡果不足惜圈膏,卻給世界環(huán)境...
    茶點故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望篙骡。 院中可真熱鬧稽坤,春花似錦丈甸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至杖玲,卻和暖如春顿仇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背摆马。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工夺欲, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人今膊。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像伞剑,于是被迫代替她去往敵國和親斑唬。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,843評論 2 354

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理黎泣,服務(wù)發(fā)現(xiàn)恕刘,斷路器,智...
    卡卡羅2017閱讀 134,656評論 18 139
  • 前段時間使用了gulp+browser-sync才發(fā)現(xiàn)這個東西真的很好用抒倚。準(zhǔn)備工作:(1)褐着、安裝nodejs。gu...
    Picidae閱讀 295評論 0 0
  • 原文標(biāo)題:Gulp for Beginners作者: Zell Liew翻譯:治電小白菜原文地址:https://...
    ZZES_ZCDC閱讀 1,583評論 6 18
  • gulpjs是一個前端構(gòu)建工具托呕,與gruntjs相比含蓉,gulpjs無需寫一大堆繁雜的配置參數(shù),API也非常簡單项郊,學(xué)...
    依依玖玥閱讀 3,152評論 7 55
  • 齋中芝蘭玉樹映風(fēng)前馅扣,白石清泉翠靄邊;照世圣經(jīng)明似鏡着降,通方古道直如弦差油;立心無罔蓋當(dāng)爾,處事有成皆偶然任洞;求彼不如...
    堅冰至_Monsol閱讀 839評論 0 50