中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

停不下來的前端,自動化流程

  流程

  關(guān)于流程,是從項目啟動到發(fā)布的過程。在前端通常我們都做些什么?

  1. 切圖,即從設(shè)計稿中獲取需要的素材,并不是所有前端開發(fā)都被要求切圖,也不是所有前端開發(fā)都會切圖,但請享受學(xué)習(xí)新知識的過程吧。
  2. 創(chuàng)建模版(html、jade、haml)、腳本(Javascript、coffeescript)、樣式(css、less、sass、stylus)文件,搭建基礎(chǔ)的項目骨架。
  3. 文件(jade、coffeescript、less、sass…)編譯
  4. 執(zhí)行測試用例
  5. 代碼檢測
  6. 移除調(diào)試代碼
  7. 靜態(tài)資源合并與優(yōu)化
  8. 靜態(tài)資源通過hash計算指紋化
  9. 部署測試環(huán)境
  10. 灰度發(fā)布現(xiàn)網(wǎng)

  工具化

  每個流程中的過程單元,我們抽象為一個Task,即任務(wù)。把可重復(fù)規(guī)則的過程進行工具化,如把JavaScript代碼壓縮過程工具化,而UglifyJS是具體執(zhí)行任務(wù)的工具,CSS代碼壓縮器CleanCSS是具體執(zhí)行任務(wù)的工具。

  工具文化幾乎是大平臺互聯(lián)網(wǎng)公司共有的特質(zhì),我們無法確定是工具文化驅(qū)動了Google、Facebook這類互聯(lián)網(wǎng)公司的快速發(fā)展,還是快速發(fā)展的需要使其在內(nèi)推廣工具文化,但可以明確的是工具文化必不可少。在Facebook第二位中國籍工程師王淮的書中也提到提到:

  當(dāng)時招聘他進Facebook的總監(jiān)黃易山,是對內(nèi)部工具的最有力倡導(dǎo)者:

他極度建議,公司要把最好的人才放到工具開發(fā)那一塊,因為工具做好了,可以達到事半功倍的效果,所有人的效率都可以得到提高,而不僅僅是工程師。

  在騰訊,工具文化雖沒有被明確指出,但大平臺公司對工具化的堅持是一致的:凡是被不斷重復(fù)的過程,將其工具化,綁定到自動化流程之中。技術(shù)產(chǎn)品也需要Don’t make me think的方式來推廣最佳實踐。總而言之:依靠工具,而不是經(jīng)驗。

  自動化流程

  任務(wù)工具化是自動化流程的基礎(chǔ),我想你已經(jīng)聽說過任務(wù)運行器Grunt。Grunt幫助開發(fā)者把任務(wù)單元建立連接,如代碼編譯Task執(zhí)行完后執(zhí)行檢測Task,檢測Task執(zhí)行完后執(zhí)行壓縮Task。雖然Grunt是基于Node.js平臺,但其定位是個通用任務(wù)管理器,通用往往意味著更高的學(xué)習(xí)與實施成本。專注于Web開發(fā)領(lǐng)域騰訊有Mod.js來實施前端自動化,通過Mod.js有效的簡化Web開發(fā)自動化流程實施成本。

  實施Mod.js

  Mod.js并不是簡單的任務(wù)運行器,其內(nèi)置集成了Web前端開發(fā)常用的工具集,覆蓋了80%的前端使用場景,而另外的20%則可通過Mod.js的插件機制來擴展。

  相遇

  Mod.js:https://github.com/modjs/mod 可通過NPM來安裝最新的版本, 在你來到Node.js的編程世界時已同時附帶了NPM,當(dāng)前Mod.js最新版本0. 4.x要求Node.js要求>= 0.8.0

$ npm install modjs -g

  -g 參數(shù)表示把Mod.js安裝到全局,如此mod命令將會在system path內(nèi),方便在任何一個目錄啟動Mod.js任務(wù)。

  相識

  Mod.js通過Modfile.js文件驅(qū)動任務(wù)執(zhí)行,可以手動創(chuàng)建一個Modfile.js文件,也可以通過模版初始化一個Modfile.js文件:

$ mod init modfile

  Modfile.js是一個Plain Node Module, 通過 Runner 對象來描述任務(wù)的具體執(zhí)行過程:

// 暴露Runner對象module.exports = {}

  如是異步配置,則可通過回調(diào)模式傳遞Runner對象:

module.exports = function(options, done){    setTimeout( function(){        // 回調(diào)Runner對象        var runner = {};        done(runner);    }, 1000)} 

it知識庫停不下來的前端,自動化流程,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美成年视频 | 欧美区日韩区 | 久久久久国产精品 | 狠狠av | 精品国产乱码久久久久久丨区2区 | 精品视频网 | 欧美a√ | 亚洲一区二区视频在线观看 | 亚洲精品久久久久久国产精华液 | 亚洲日本激情 | 国产精品一区二区av | 在线播放国产一区二区三区 | 欧美美乳| 亚洲精品小视频在线观看 | 国产乱人伦 | 中文字幕日韩欧美一区二区三区 | yeyeav| 欧美一区二区三区在线观看 | 久久精品屋 | 国产精品一区二区免费 | 久久精品免费观看 | 欧美日韩成人在线 | 免费视频二区 | 久久丝袜| 综合伊人 | 九九久久精品视频 | 久久成人精品视频 | 亚洲一区二区三区桃乃木香奈 | 久久久久久久久中文字幕 | 欧美日韩三级视频 | 中文字幕成人av | 日韩欧美精品 | 精品欧美一区二区三区久久久 | 日本免费一区二区三区 | 精品无码久久久久久国产 | 亚洲国产成人精品久久 | 日韩欧美在线视频观看 | 国产目拍亚洲精品99久久精品 | 亚洲欧美日韩国产 | 久久精品国产亚洲a | 日本 欧美 三级 高清 视频 |