日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何構(gòu)建自動化的前端開發(fā)流程

如今的前端開發(fā)中,已經(jīng)不再只是一些簡單的靜態(tài)文件了,對于很多Web App來說,前端代碼甚至比后端代碼要更加復(fù)雜,更加難于管理,例如:

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、重慶小程序開發(fā)公司、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了津南免費建站歡迎大家使用!

  • 我們有許多的第三方庫的依賴需要管理;
  • 我們有獨立的前端測試需要自動運行;
  • 我們還有很多代碼需要在發(fā)布時進行打包壓縮;
  • ??

所以構(gòu)建一個自動化的前端開發(fā)流程是非常必要的,但現(xiàn)在前端開發(fā)流程的構(gòu)建是百花齊放,沒有一個統(tǒng)一的標準,還有很多依賴于后端的架構(gòu)來做前端開發(fā)管理。例如在Rails開發(fā)中,就有各種前端庫的gem包。但是這種依賴于后端框架的管理方式有許多問題:

  • 許多gem包的維護者并不是前端庫的維護者,所以更新不一定即時;
  • 不利于前端代碼與后端代碼做分離;
  • 增加了前端開發(fā)者的學(xué)習(xí)和使用成本;
  • ??

[[84676]]

于是現(xiàn)在出現(xiàn)了一些不依賴于后端代碼(雖然還是要依賴Node.js??)的管理工具,對于前端開發(fā)者非常友好,例如:YEMAN、Jam、volo、component、Brunch??但是這些工具都或多或少有自己的一些問題,所以我決定用一些更輕量的工具(bower、grunt)來搭建自己的前端開發(fā)流程。本文的例子來自本人正在開發(fā)的一個項目,可以在github上查看所有的代碼。

什么是開發(fā)流程?

在我看來一個完整的開發(fā)流程應(yīng)該包括:

  • 本地開發(fā)環(huán)境的初始化
  • 第三方依賴的管理
  • 源文件編譯
  • 自動化測試
  • 發(fā)布到pipeline和各個環(huán)境

而現(xiàn)代的開發(fā)流程,就是要使上面的各個部分都可以自動化,一個命令就可以使這些流程都自動走完,并且快速的得到錯誤或通過的反饋,讓我們可以方便快速的修復(fù)錯誤和release。

本地開發(fā)環(huán)境的初始化

這里我使用的工具是Node.js和NPM,它們都基于JavaScript,使用Json來配置,對于前端開發(fā)人員非常友好。

安裝完成Node.js和NPM后,在項目根目錄下創(chuàng)建NPM的配置文件package.json

 
 
 
  1.     "name": "Project Name", 
  2.     "version": "0.0.1", 
  3.     "description": "Project Description", 
  4.     "repository": { 
  5.         "type": "git", 
  6.         "url": "git://github.com/path/to/your_project" 
  7.     }, 
  8.     "author": "Author Name", 
  9.     "license": "BSD", 
  10.     "readmeFilename": "README.md", 
  11.     "gitHead": "git head", 
  12.     "devDependencies": { 
  13.         "grunt": "latest", 
  14.         "grunt-contrib-connect": "latest", 
  15.         "grunt-contrib-concat": "latest", 
  16.         "grunt-contrib-jasmine": "latest", 
  17.         "grunt-contrib-watch": "latest", 
  18.         "grunt-contrib-compass": "latest" 
  19.     } 

其中最重要的一個配置項是devDependencies,這是用于開發(fā)的依賴,例如:自動化測試、源文件編譯等等,其中各個依賴的作用和用法將會在后面講到。而前端生產(chǎn)代碼的依賴會使用另一個工具來管理,也在后面講到。創(chuàng)建完成以后運行npm install,NPM就會將這些依賴都安裝到項目根目錄的node_modules文件夾中。

第三方依賴的管理

這里我使用的工具是bower。 其實NPM也可以管理,但是NPM并不是讀取第三方依賴原始的repository,而是讀取自己管理的一個repository,所以更新可能會慢點, 并且它使用CommonJS的接口方便Node.js項目的開發(fā),并不是針對純前端開發(fā)的項目;而bower是讀取原始的github repository,沒有更新延遲的問題,所有包都是針對純前端開發(fā)項目的。

要使用bower只需要簡單的三步:

  1. 安裝:npm install bower -g
  2. 在項目根目錄中創(chuàng)建配置文件.bowerrc
  3. 在項目根目錄中創(chuàng)建依賴配置文件components.json

我們首先來看看.bowerrc的內(nèi)容:

 
 
 
  1.     "directory" : "components", 
  2.     "json"      : "component.json", 
  3.     "endpoint"  : "https://bower.herokuapp.com" 

其中directory指定了所有的依賴會被安裝到哪里;json指定了依賴配置文件的路徑;endpoint制定了依賴的repository的尋址服務(wù)器,你可以替換為自己的尋址服務(wù)器。

然后我們來看看components.json的內(nèi)容:

 
 
 
  1.     "name": "Project Name", 
  2.     "version": "0.0.1", 
  3.     "dependencies": { 
  4.       "jquery": "latest", 
  5.       "underscore": "latest", 
  6.       "backbone": "latest", 
  7.       "jasmine-jquery": "latest", 
  8.       "jasmine-ajax": "git@github.com:pivotal/jasmine-ajax.git" 
  9.     } 

其中最重要的就是dependencies,它指定了所有前端開發(fā)依賴的包。所有bower包含的依賴都可以在這里查到,對于bower沒有包含的依賴也可以直接指定github的repository,例如:"jasmine-ajax": "git@github.com:pivotal/jasmine-ajax.git"。

最后運行bower install就可以在components文件夾中看到所有第三方依賴的文件了。但是bower有一個問題,就是它將所有g(shù)ithub repository中的文件都下載下來了,其中有許多是我們不需要的文件。下面我們會將我們需要的文件提取出來打包放到我們指定的目錄中。

#p#

源文件編譯

這里我使用的工具是grunt,他本身主要是基于Node.js的文件操作包,其中有許多插件可以讓我們完成js文件的compile和compress、sass到css的轉(zhuǎn)換等等操作。要使用它需要先安裝命令行工具:npm install grunt-cli -g,然后在項目根目錄中創(chuàng)建文件Gruntfile.js,這個文件用于定義各種task,我們首先定義一個task將從bower下載的第三方依賴都打包到文件app/js/lib.js中:

 
 
 
  1. module.exports = function(grunt) { 
  2.     var dependencies = [ 
  3.         'components/jquery/jquery.js', 
  4.         'components/underscore/underscore.js', 
  5.         'components/backbone/backbone.js']; 
  6.     grunt.initConfig({ 
  7.         concat: { 
  8.             js: { 
  9.                 src: dependencies, 
  10.                 dest: 'app/js/lib.js' 
  11.             } 
  12.         } 
  13.     }); 
  14.     grunt.loadNpmTasks('grunt-contrib-concat'); 
  15. }; 

這里的grunt-contrib-concat就是grunt的一個插件,用于文件的合并操作,我們已經(jīng)在前面的package.json中引入了。js是task name;src指定了合并的源文件地址;dest指定了合并的目標文件。這樣當我們運行grunt concat:js后,所有的依賴文件都會被合并為app/js/lib.js。這樣做的好處是我們可以控制每個依賴的引入順序,但是麻煩的是每次引入新的依賴都需要手動加入到dependencies數(shù)組中。這個暫時沒有更好的解決方案,因為不是所有的包都在自己的components.js中聲明了main文件,很多時候必須自己手動指定。

JavaScript文件編譯完成以后就是CSS文件,在現(xiàn)代的前端開發(fā)中,我們已經(jīng)很少直接寫CSS文件了,一般都使用SASS或者LESS。grunt也提供了這種支持,這里我使用的是grunt-contrib-compass:

 
 
 
  1. module.exports = function(grunt) { 
  2.     var sasses = 'sass'; 
  3.     grunt.initConfig({ 
  4.         compass: { 
  5.             development: { 
  6.                 options: { 
  7.                     sassDir: sasses, 
  8.                     cssDir: 'app/css' 
  9.                 } 
  10.             } 
  11.         } 
  12.     }); 
  13.     grunt.loadNpmTasks('grunt-contrib-compass'); 
  14. }; 

然后運行grunt compass:development就可以完成CSS文件的編譯了。

自動化測試

這里我使用的自動化測試工具是Jasmine,它grunt中同樣有一個插件:grunt-contrib-jasmine。下面我們來看看如何在Gruntfile.js中定義測試的task:

 
 
 
  1. module.exports = function(grunt) { 
  2.     var sources = 'app/js/**/*.js', 
  3.         specs = 'spec/**/*Spec.js'; 
  4.     grunt.initConfig({ 
  5.         jasmine: { 
  6.             test: { 
  7.                 src: [sources], 
  8.                 options: { 
  9.                     specs: specs, 
  10.                     helpers: ['spec/helper/**/*.js'], 
  11.                     vendor: 'app/js/lib.js' 
  12.                 } 
  13.             } 
  14.         } 
  15.     }); 
  16.     grunt.loadNpmTasks('grunt-contrib-jasmine'); 
  17. }; 

配置完成以后就可以運行grunt jasmine:test來跑測試,但問題是每次寫完代碼都要手動執(zhí)行一次非常麻煩,最好可以每次代碼有更改都自動跑一次,讓我們可以更快的得到反饋。grunt的watch插件就提供了這種支持:

 
 
 
  1. module.exports = function(grunt) { 
  2.     var sources = 'app/js/**/*.js', 
  3.         specs = 'spec/**/*Spec.js'; 
  4.     grunt.initConfig({ 
  5.         jasmine: { 
  6.             test: { 
  7.                 src: [sources], 
  8.                 options: { 
  9.                     specs: specs, 
  10.                     helpers: ['spec/helper/**/*.js'], 
  11.                     vendor: 'app/js/lib.js' 
  12.                 } 
  13.             } 
  14.         }, 
  15.         watch: { 
  16.             test: { 
  17.                 files: [sources, specs], 
  18.                 tasks: ['jasmine:test'] 
  19.             } 
  20.         } 
  21.     }); 
  22.     grunt.loadNpmTasks('grunt-contrib-jasmine'); 
  23.     grunt.loadNpmTasks('grunt-contrib-watch'); 
  24. }; 

files指定了需要監(jiān)聽變動的文件;tasks指定了修改后自動觸發(fā)的task?,F(xiàn)在只要我們運行grunt watch:test,那么有任何源文件、測試文件的改動,Jasmine測試都會自動運行了。有時候我們也希望測試的結(jié)果顯示在網(wǎng)頁上,便于我們做js的調(diào)試。那么可以將tasks:['jasmine:test']改為tasks: ['jasmine:test:build'],然后打開根目錄下的_SpecRunner.html文件,就可以在網(wǎng)頁中看到測試結(jié)果了,再加上一些Chrome的Livereload插件,就可以不用刷新實時的看到測試結(jié)果,效率非常之高。雖然grunt插件中也有l(wèi)ivereload,但是與grunt-contrib-watch無法很好的集成,所以我沒有使用這種方式。

CI Pipeline

由于我的項目是host在github上,所以我選擇travis-ci作為我的CI服務(wù)器。要啟用travis-ci需要以下幾步:

  1. 在travis-ci中注冊一個賬號,獲取一個token;
  2. 在你的github項目的Settings–>Service Hooks中找到Travis,填入token并且啟用;
  3. 回到travis-ci,在Accounts–>Repositories中打開你的項目的service hook
  4. Push一個.travis.yml到github,觸發(fā)第一次build。
  5. 修改package.jsonscripts項,指定運行測試的命令

下面我們來看看如何配置.travis.yml

 
 
 
  1. language: node_js 
  2. node_js: 
  3.   - "0.8" 
  4. before_script: 
  5.   - npm install -g grunt-cli 

由于我們的環(huán)境是基于Node.js搭建的,所以在language設(shè)置了nodejs;而**nodejs指定了Node.js的版 本;before_script**指定了在測試運行前需要執(zhí)行的命令,由于我們的腳本都是基于grunt的,所以需要先安裝grunt的命令行包。

然后再修改package.json

 
 
 
  1.     ?? 
  2.     "scripts": { 
  3.         "test": "grunt jasmine:test" 
  4.     } 
  5.     ?? 

將修改以后的package.jsonpush到github上,再次觸發(fā)一個新的build,你可以看到你之前錯誤的build已經(jīng)綠了。

這里還有一個小提示:如何讓build狀態(tài)顯示在項目的readme中?很簡單,只需要在README.md中加入以下代碼就可以了:

 
 
 
  1. [![Build Status](https://travis-ci.org/path/to/your_repository.png?branch=master)](http://travis-ci.org/path/to/your_repository) 

到這里基本的環(huán)境搭建就完成了,當然我們還可以使用grund的registerTask來定義一個任務(wù)序列,還可以加 入template的編譯??這些都可以通過grunt來靈活設(shè)置。最重要的是現(xiàn)在別人拿到一個項目的代碼以后,可以通過一些命令來快速的搭建本地環(huán)境, 方便的進行測試和開發(fā),而且沒有依賴與后端的開發(fā)環(huán)境,只要定義好接口,前端開發(fā)可以完全獨立開了。雖然這其中還有很多問題沒有解決,例如:

  • 如何讓第三方依賴自申明main文件
  • package.jsoncomponents.json其實有些重復(fù)
  • Live Reload還需要Chrome插件才能完成
  • ??

這正是由于現(xiàn)在前端開發(fā)環(huán)境還沒有后端開發(fā)的那種標準化,也正是挑戰(zhàn)和機遇之所在!


當前文章:如何構(gòu)建自動化的前端開發(fā)流程
網(wǎng)站網(wǎng)址:http://m.5511xx.com/article/cdojojs.html