使用GruntJS鏈接與壓縮多個(gè)JavaScript文件過(guò)程詳解
更新時(shí)間:2013年08月02日 16:31:56 作者:
怎么把多個(gè)JS文件搞成一個(gè)啊,GruntJS – JavaScript多文件編譯,風(fēng)格檢查,鏈接與壓縮神器,使用過(guò)程如下,有需要的朋友可以參考下,希望對(duì)大家有所幫助
自己寫了個(gè)簡(jiǎn)單的HTML5 Canvas的圖表庫(kù),可以支持餅圖,折線圖,散點(diǎn)圖,盒子圖 柱狀圖,同時(shí)支持鼠標(biāo)提示,繪制過(guò)程動(dòng)畫(huà)效果等。最終我想把這些多個(gè)JS文件變成 一個(gè)JS文件發(fā)布出去,于是我的問(wèn)題來(lái)啦,怎么把這些JS文件搞成一個(gè)啊,群里有個(gè) 朋友告訴我,GruntJS – JavaScript多文件編譯,風(fēng)格檢查,鏈接與壓縮神器。Google了一 把終于幫我完成這個(gè)任務(wù),算是入門,分享一下過(guò)程。
一什么是GruntJS
不想翻譯英文,自己看它的網(wǎng)站吧->http://gruntjs.com/
二:安裝與運(yùn)行
它的官方教程說(shuō)的不是很清楚,有點(diǎn)讓第一次看的人云里霧里的。我總結(jié)一下,GruntJS
是基于與依賴服務(wù)器node.js的。所以首先第一步是下載并安裝node.js,下載地址:
http://nodejs.org/download/
第二步:運(yùn)行安裝grunt命令行工具– 目的是為了使用grunt命令
只有在windows的命令行窗口中運(yùn)行:npm install -g grunt-cli即可。更具體的解釋參見(jiàn)這里:http://gruntjs.com/getting-started
第三步:在項(xiàng)目的根目錄創(chuàng)建project.json與Gruntfile.js兩個(gè)文件
因?yàn)間runt的task運(yùn)行要依賴于這兩個(gè)文件。
其中創(chuàng)建project.json文件方法可以通過(guò)命令行實(shí)現(xiàn):nmp init我創(chuàng)建project.json
內(nèi)容如下:
{
"name": "fishchart",
"version": "0.0.1",
"description": "html5 canvas chart library",
"author": "zhigang",
"license": "BSD",
"devDependencies": {
"grunt": "~0.4.1",
"grunt-contrib-uglify": "~0.2.2",
"grunt-contrib-jshint": "~0.6.2",
"grunt-contrib-concat": "~0.3.0"
}
}
使用命令創(chuàng)建時(shí)候,如果你不知道寫什么直接回車跳過(guò)即可。
三: 安裝與使用Grunt Plug-in完成javascript文件鏈接與壓縮
1. 安裝javascript文件鏈接插件支持
npm install grunt-contrib-concat --save-dev
2. 安裝javascript文件壓縮插件支持
npm install grunt-contrib-uglify --save-dev
3. 在Gruntfile.js文件中配置選項(xiàng),加載與定義task
module.exports = function(grunt) {
grunt.initConfig({
//our JSHint options
jshint: {
all: ['main.js'] //files to lint
},
//our concat options
concat: {
options: {
separator: ';' //separates scripts
},
dist: {
src: ['js/*.js', 'js/**/*.js'], //Grunt mini match for your scripts to concatenate
dest: 'js/fishchart_v0.0.1.js' //where to output the script
}
},
//our uglify options
uglify: {
js: {
files: {
'js/fishchart_v0.0.1.js': ['js/fishchart_v0.0.1.js'] //save over the newly created script
}
}
}
});
//load our tasks
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
// default tasks to run
// grunt.registerTask('default', ['jshint', 'concat', 'uglify']);
grunt.registerTask('development', ['jshint']);
grunt.registerTask('production', ['jshint', 'concat', 'uglify']);
}
四:運(yùn)行結(jié)果
最后還想贊一下,這個(gè)東西太好用啦!
一什么是GruntJS
不想翻譯英文,自己看它的網(wǎng)站吧->http://gruntjs.com/
二:安裝與運(yùn)行
它的官方教程說(shuō)的不是很清楚,有點(diǎn)讓第一次看的人云里霧里的。我總結(jié)一下,GruntJS
是基于與依賴服務(wù)器node.js的。所以首先第一步是下載并安裝node.js,下載地址:
http://nodejs.org/download/
第二步:運(yùn)行安裝grunt命令行工具– 目的是為了使用grunt命令
只有在windows的命令行窗口中運(yùn)行:npm install -g grunt-cli即可。更具體的解釋參見(jiàn)這里:http://gruntjs.com/getting-started
第三步:在項(xiàng)目的根目錄創(chuàng)建project.json與Gruntfile.js兩個(gè)文件
因?yàn)間runt的task運(yùn)行要依賴于這兩個(gè)文件。
其中創(chuàng)建project.json文件方法可以通過(guò)命令行實(shí)現(xiàn):nmp init我創(chuàng)建project.json
內(nèi)容如下:
復(fù)制代碼 代碼如下:
{
"name": "fishchart",
"version": "0.0.1",
"description": "html5 canvas chart library",
"author": "zhigang",
"license": "BSD",
"devDependencies": {
"grunt": "~0.4.1",
"grunt-contrib-uglify": "~0.2.2",
"grunt-contrib-jshint": "~0.6.2",
"grunt-contrib-concat": "~0.3.0"
}
}
使用命令創(chuàng)建時(shí)候,如果你不知道寫什么直接回車跳過(guò)即可。
三: 安裝與使用Grunt Plug-in完成javascript文件鏈接與壓縮
1. 安裝javascript文件鏈接插件支持
npm install grunt-contrib-concat --save-dev
2. 安裝javascript文件壓縮插件支持
npm install grunt-contrib-uglify --save-dev
3. 在Gruntfile.js文件中配置選項(xiàng),加載與定義task
復(fù)制代碼 代碼如下:
module.exports = function(grunt) {
grunt.initConfig({
//our JSHint options
jshint: {
all: ['main.js'] //files to lint
},
//our concat options
concat: {
options: {
separator: ';' //separates scripts
},
dist: {
src: ['js/*.js', 'js/**/*.js'], //Grunt mini match for your scripts to concatenate
dest: 'js/fishchart_v0.0.1.js' //where to output the script
}
},
//our uglify options
uglify: {
js: {
files: {
'js/fishchart_v0.0.1.js': ['js/fishchart_v0.0.1.js'] //save over the newly created script
}
}
}
});
//load our tasks
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-contrib-uglify');
// default tasks to run
// grunt.registerTask('default', ['jshint', 'concat', 'uglify']);
grunt.registerTask('development', ['jshint']);
grunt.registerTask('production', ['jshint', 'concat', 'uglify']);
}
四:運(yùn)行結(jié)果

最后還想贊一下,這個(gè)東西太好用啦!
您可能感興趣的文章:
- Node.js的項(xiàng)目構(gòu)建工具Grunt的安裝與配置教程
- 使用基于Node.js的構(gòu)建工具Grunt來(lái)發(fā)布ASP.NET MVC項(xiàng)目
- 學(xué)習(xí)使用grunt來(lái)打包JavaScript和CSS程序的教程
- 配置Grunt的Task時(shí)通配符支持和動(dòng)態(tài)生成文件名問(wèn)題
- Grunt入門教程(自動(dòng)任務(wù)運(yùn)行器)
- 詳解Grunt插件之LiveReload實(shí)現(xiàn)頁(yè)面自動(dòng)刷新(兩種方案)
- 使用GruntJS構(gòu)建Web程序之Tasks(任務(wù))篇
- 使用GruntJS構(gòu)建Web程序之合并壓縮篇
- 使用GruntJS構(gòu)建Web程序之構(gòu)建篇
- 使用GruntJS構(gòu)建Web程序之安裝篇
- 使用Grunt.js管理你項(xiàng)目的應(yīng)用說(shuō)明
- 基于Node.js的JavaScript項(xiàng)目構(gòu)建工具gulp的使用教程
相關(guān)文章
微信小程序搭建(mpvue+mpvue-weui+fly.js)的詳細(xì)步驟
這篇文章主要介紹了微信小程序搭建(mpvue+mpvue-weui+fly.js)的詳細(xì)步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09ES6數(shù)組與對(duì)象的解構(gòu)賦值詳解
這篇文章主要介紹了ES6數(shù)組與對(duì)象的解構(gòu)賦值,結(jié)合實(shí)例形式詳細(xì)分析了ES6中數(shù)組與對(duì)象的解構(gòu)賦值原理、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-06-06純js三維數(shù)組實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了純js三維數(shù)組實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02詳解TypeScript中的箭頭函數(shù)如何實(shí)現(xiàn)重載
這篇文章主要為大家詳細(xì)介紹了TypeScript中的箭頭函數(shù)是如何實(shí)現(xiàn)重載的,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,需要的可以參考一下2023-05-05漂亮的widgets,支持換膚和后期開(kāi)發(fā)新皮膚
漂亮的widgets,支持換膚和后期開(kāi)發(fā)新皮膚...2007-04-04微信小程序?qū)崿F(xiàn)form表單本地儲(chǔ)存數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)form表單本地儲(chǔ)存數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06