yeoman bower grunt

一、Yeoman是Google的團(tuán)隊(duì)和外部貢獻(xiàn)者團(tuán)隊(duì)合作開發(fā)的,他的目標(biāo)是通過Grunt(一個(gè)用于開發(fā)任務(wù)自動(dòng)化的命令行工具)和Bower(一個(gè)HTML、CSS、Javascript和圖片等前端資源的包管理器)的包裝為開發(fā)者創(chuàng)建一個(gè)易用的工作流。

1.安裝yeoman

npm install -g yo

2.安裝generator-webapp庫

npm install -g generator-webapp

3.yo webapp快速構(gòu)建一個(gè)web項(xiàng)目

yo webapp

二、bower
Bower 是 twitter 推出的一款包管理工具,基于nodejs的模塊化思想,把功能分散到各個(gè)模塊中,讓模塊和模塊之間存在聯(lián)系,通過 Bower 來管理模塊間的這種聯(lián)系。
1.安裝bower

npm install bower -g

2.項(xiàng)目初始化,通過回答幾個(gè)問題,就會(huì)自動(dòng)生成bower.json文件。這是項(xiàng)目的配置文件

bower init

3.配置文件.bowerrc
項(xiàng)目根目錄下(也可以放在用戶的主目錄下)的.bowerrc文件是Bower的配置文件,它大概像下面這樣

{
  "directory" : "components",
  "json"      : "bower.json",
  "endpoint"  : "https://Bower.herokuapp.com",
  "searchpath"  : "",
  "shorthand_resolver" : ""
}

其中的屬性含義如下

directory:存放庫文件的子目錄名。
json:描述各個(gè)庫的json文件名。
endpoint:在線索引的網(wǎng)址,用來搜索各種庫。
searchpath:一個(gè)數(shù)組,儲(chǔ)存?zhèn)溥x的在線索引網(wǎng)址。如果某個(gè)庫在endpoint中找不到,則繼續(xù)搜索該屬性指定的網(wǎng)址,通常用于放置某些不公開的庫。
shorthand_resolver:定義各個(gè)庫名稱簡寫形式。

2.庫的安裝,安裝jquery

bower install jquery

3.生成bower.json配置文件

bower init

三、gruntI(http://javascript.ruanyifeng.com/tool/grunt.html)
1.安裝grunt-cli
grunt-cli并不grunt,grunt-cli的作用是管理本地各版本的grunt,讓命令行可以直接執(zhí)行g(shù)runt命令。
grunt-cli表示安裝的是grunt的命令行界面,參數(shù)g表示全局安裝。

npm install -g grunt-cli

2全局安裝grunt

npm install -g grunt

grunt命令執(zhí)行,是需要當(dāng)前目錄中包括package.json和Gruntfile.js兩個(gè)文件。
package.json,是npm項(xiàng)目配置文件
Gruntfile.js,是專門用來配置grunt的配置文件
3.自動(dòng)生成package.json文件

npm init

4.如果已有的package.json文件不包括Grunt模塊,可以在直接安裝Grunt模塊的時(shí)候,加上–save-dev參數(shù),該模塊就會(huì)自動(dòng)被加入package.json文件。

npm install grunt --save-dev

安裝-save-dev,就可以,直接把grunt作為devDependencies寫入的package.json中。
5.命令腳本文件Gruntfile.js
新建腳本文件Gruntfile.js。它是grunt的配置文件就好像package.json是npm的配置文件一樣。Gruntfile.js就是一般的Node.js模塊的寫法。

module.exports = function(grunt) {

  // 配置Grunt各種模塊的參數(shù)
  grunt.initConfig({
    jshint: { /* jshint的參數(shù) */ },
    concat: { /* concat的參數(shù) */ },
    uglify: { /* uglify的參數(shù) */ },
    watch:  { /* watch的參數(shù) */ }
  });

  // 從node_modules目錄加載模塊文件
  grunt.loadNpmTasks('grunt-contrib-jshint');
  grunt.loadNpmTasks('grunt-contrib-concat');
  grunt.loadNpmTasks('grunt-contrib-uglify');
  grunt.loadNpmTasks('grunt-contrib-watch');

  // 每行registerTask定義一個(gè)任務(wù)
  grunt.registerTask('default', ['jshint', 'concat', 'uglify']);
  grunt.registerTask('check', ['jshint']);

};

上面的代碼用到了grunt代碼的三個(gè)方法:

grunt.initConfig:定義各種模塊的參數(shù),每一個(gè)成員項(xiàng)對(duì)應(yīng)一個(gè)同名模塊。

grunt.loadNpmTasks:加載完成任務(wù)所需的模塊。

grunt.registerTask:定義具體的任務(wù)。第一個(gè)參數(shù)為任務(wù)名,第二個(gè)參數(shù)是一個(gè)數(shù)組,表示該任務(wù)需要依次使用的模塊。default任務(wù)名表示,如果直接輸入grunt命令,后面不跟任何參數(shù),這時(shí)所調(diào)用的模塊(該例為jshint,concat和uglify);該例的check任務(wù)則表示使用jshint插件對(duì)代碼進(jìn)行語法檢查。

5.Grunt常用插件
grunt-contrib-uglify:壓縮js代碼
grunt-contrib-concat:合并js文件
grunt-contrib-qunit:單元測(cè)試
grunt-contrib-jshint:js代碼檢查
grunt-contrib-watch:監(jiān)控文件修改并重新執(zhí)行注冊(cè)的任務(wù)

npm init
npm install grunt --save-dev
npm install load-grunt-tasks --save-dev
npm install time-grunt --save-dev
npm install grunt-contrib-copy --save-dev
npm install grunt-contrib-clean --save-dev


grunt copy
grunt clean


yo webapp grunt-yo-webapp
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,565評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,115評(píng)論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,577評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,514評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,234評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,621評(píng)論 1 326
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,641評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,822評(píng)論 0 289
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,380評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,128評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,319評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,879評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,548評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,970評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,229評(píng)論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,048評(píng)論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,285評(píng)論 2 376

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