Package.js 現(xiàn)代化的JavaScript項(xiàng)目make工具
Package.js是一個(gè)很方便的JavaScript包依賴管理及Make工具。它的設(shè)計(jì)目標(biāo)是使瀏覽器端的JavaScript Component/App 開發(fā)更加模塊化。如果您只是在開發(fā)一個(gè)小型的網(wǎng)站,只會(huì)混雜在HTML中寫幾行JS代碼用于改善一下用戶體驗(yàn),那么Package.js也許并不適合您。如果您正在開發(fā)一個(gè)中到大型的WebApp,有幾十甚至幾百幾千個(gè)JS文件和CSS文件、HTML模板文件,如果您正在為管理這些JS模塊之間的依賴和加載而煩惱,為發(fā)布到生產(chǎn)環(huán)境時(shí)將JS文件合并打包而寫Makefile寫得頭暈,那么,Package.js,這就是你想要的!趕快來了解并使用Package.js吧!
Package.js主要包含兩個(gè)部分
運(yùn)行在瀏覽器中的,用于define及import模塊的JS庫(kù)API
運(yùn)行在node.js環(huán)境,將所有JS包及其依賴的CSS及HTML文件合并的make工具
Package.js瀏覽器端的API參照了CommonJS/AMD規(guī)范,兼容此規(guī)范的最簡(jiǎn)單形式,并在此基礎(chǔ)擴(kuò)展了一些語法,以便于開發(fā)包含CSS及HTML模板的JavaScript UI組件。
直接來看一下使用Package.js開發(fā)的項(xiàng)目的目錄結(jié)構(gòu)吧,簡(jiǎn)單明了:
Test
├── dom
│ └── Style.js #命名空間為Test.dom.Style的模塊文件
├── init.js #根命名空間初始化文件
├── _nsconf_.js #Package.js會(huì)讀取的配置文件
├── ui
│ ├── Button
│ │ ├── img
│ │ │ └── bg.png
│ │ ├── init.js #Test.ui.Button命名空間的模塊文件
│ │ ├── style.css #UI組件的CSS文件
│ │ └── tpl.html #UI組件的HTML模板文件
│ └── Form
│ ├── init.js
│ ├── style.css
│ └── tpl.html
├── util
│ └── Cookie.js #命名空間為Test.util.Cookie的JS包
└── _xproxy_.html -> ../Package/_xproxy_.html #此文件為Soft Link指向Package.js源碼中的Package/_xproxy_.html,用于跨域加載HTML模板文件
使用Package.js,模塊的定義語法——
Root/ui/Button/init.js代碼:
Package.define("Root.ui.Button",["Root.ui.Pane","Root.util.Tpl","Root.util.Event"],
function (Pane,Tpl,Event) {
//Pane為Root.ui.Pane
//Tpl對(duì)應(yīng)Root.util.Tpl
//依此類推
//.....
});
與CommonJS的AMD規(guī)范不同,在Package.js的語法中,一個(gè)JS模塊,不但可以依賴其它JS包,還可以依賴CSS及HTML模板文件、及其它的JSON數(shù)據(jù)文件,并在運(yùn)行時(shí),獲取到依賴的其它文件的內(nèi)容。定義語法如下:
Package.define("NS.ui.Button",["MT.ui.Component"],
{
tpl:"tpl.html",
_style:"style.css"
},function (Component) {
//通過this.assets.tpl訪問tpl.html內(nèi)容
var bgImgUrl=this.path+"img/bg.png",tpl=this.assets.tpl;
function Button(opt) {
//也可以通過當(dāng)前Package對(duì)象的_pkgMeta_屬性訪問assets
this.tpl=String2Dom(opt.tpl || Button._pkgMeta_.assets.tpl);
}
return Button;
})
在瀏覽器中,可以使用下面的方法導(dǎo)入一個(gè)JS模塊,
在導(dǎo)入的過程中,Package.js自動(dòng)幫您做了后勤工作:1、加載這個(gè)模塊的依賴模塊。2、加載依賴的HTML及CSS文件。
Package.imports(["Root.ui.Button"],function (Button) {
var btn=new Button();
btn.renderTo(document.body);
});
在開發(fā)時(shí),為了模塊化,您需要將JS分成一個(gè)一個(gè)小的模塊文件,但發(fā)布到生產(chǎn)環(huán)境時(shí),為了加載速度上的考慮,您需要將這些JS文件合并成單個(gè)的JS文件并壓縮,同樣,CSS文件也要合并到一起。
//您的打包配置文件
//build-config.json文件內(nèi)容
{
"staticUrls": {"defaults":"http://statics.iwt.macrotarget.com/jslibs/"},
"nsconfs":["http://www.cnblogs.com/statics/jslibs/XLib/_nsconf_.js"],
"includes":["XLib.apps.MainApp","XLib.ui.*"],
"compress":true //使用UglifyJS和UglifyCSS進(jìn)行壓縮
}
借助Package.js,完成這個(gè)功能,您只需要寫三四行JSON配置代碼,執(zhí)行一個(gè)命令,就一切OK了。
#執(zhí)行命令
build.js build-config.json js all.min.js
build.js build-config.json css all.min.css
#腰不酸了,腿不疼了!
引用
PS:build.js還幫您做掉一個(gè)小事:將CSS文件中的background:url()之類的相對(duì)路徑轉(zhuǎn)換成絕對(duì)URL。您在開發(fā)時(shí),CSS中url()始終只需要寫相對(duì)路徑,在部署到生產(chǎn)環(huán)境時(shí),build.js合并后的CSS會(huì)自動(dòng)將其轉(zhuǎn)換成絕對(duì)URL。甚至,如果你有使用IE6 Png AlphaImageLoader濾鏡,使用wui4ie6的loader,您在開發(fā)時(shí)仍然可以在src=里寫相對(duì)路徑,在開發(fā)模式下,Package.js也會(huì)自動(dòng)生成使用絕對(duì)URL的CSS Rule,在打包時(shí)也會(huì)對(duì) AlphaImageLoader的src作轉(zhuǎn)換,CSS中永遠(yuǎn)不需要寫絕對(duì)URL
Package.js相比于其它模塊加載器及AMD實(shí)現(xiàn)(RequireJS,SeaJS...)有什么優(yōu)勢(shì)或缺點(diǎn)?
Package.js是面向Web App Framework開發(fā),定義語法及文件目錄結(jié)構(gòu)較嚴(yán)格(或者說稍顯復(fù)雜),只使用AMD規(guī)范中最簡(jiǎn)單的一種define語法
Package.js將JS模塊對(duì)CSS及HTML文件的依賴與對(duì)其它JS模塊的依賴在define寫法上區(qū)分開來,并且在build.js中也包含了對(duì)CSS、HTML、JSON打包的處理
(TOT)包含對(duì)IE6 CSS的特殊照顧(沒辦法,我們自己的項(xiàng)目需要)
增加PackageMeta,一個(gè)JS模塊在運(yùn)行時(shí)可以知道自己的URL
...如果算缺點(diǎn)的話:不與CommonJS AMD規(guī)范完全兼容
build時(shí)支持三種導(dǎo)出模式:includes,deps,all
開發(fā)模式下更方便:使用_xproxy_.html跨域加載,無需代理。使用_nsconf_.js,無需配置paths。
聽完這些簡(jiǎn)單的介紹或許您對(duì)Package.js已經(jīng)躍躍欲試了,在使用之前,您可以參考下
Package.js的詳細(xì)文檔:http://package-js.googlecode.com/hg/docs/Package.html。
好!不要再用落后的方式開發(fā)JavaScript App,不要再做Out Man,趕快使用Package.js吧 ^O^
- JavaScript讀寫二進(jìn)制數(shù)據(jù)的方法詳解
- JavaScript實(shí)現(xiàn)JSON合并操作示例【遞歸深度合并】
- JavaScript函數(shù)、閉包、原型、面向?qū)ο髮W(xué)習(xí)筆記
- JavaScript使用indexOf()實(shí)現(xiàn)數(shù)組去重的方法分析
- JavaScript日期工具類DateUtils定義與用法示例
- Reactnative-iOS回調(diào)Javascript的方法
- JavaScript實(shí)現(xiàn)簡(jiǎn)單的隱藏式側(cè)邊欄功能示例
- 詳解vue-cli 腳手架項(xiàng)目-package.json
- package.json文件配置詳解
- 詳解Nodejs之npm&package.json
- nodejs npm package.json中文文檔
- Javascript 之封裝(Package)
相關(guān)文章
JavaScript中16進(jìn)制顏色與rgb顏色互相轉(zhuǎn)換的示例代碼
這篇文章主要介紹了JavaScript中16進(jìn)制顏色與rgb顏色互相轉(zhuǎn)換的示例代碼,通過示例代碼介紹了JS 顏色16進(jìn)制、rgba相互轉(zhuǎn)換問題,感興趣的朋友一起看看吧2024-01-01解決layui上傳文件提示上傳異常,實(shí)際文件已經(jīng)上傳成功的問題
今天小編就為大家分享一篇解決layui上傳文件提示上傳異常,實(shí)際文件已經(jīng)上傳成功的問題。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08JS 添加網(wǎng)頁(yè)桌面快捷方式的代碼詳細(xì)整理
如何添加桌面快捷?很多網(wǎng)友都有這個(gè)疑問;JS 點(diǎn)擊添加網(wǎng)頁(yè)桌面快捷方式的代碼,需要的朋友可以參考下2012-12-12javascript實(shí)現(xiàn)圖片輪換動(dòng)作方法
這篇文章主要介紹了javascript實(shí)現(xiàn)圖片輪換動(dòng)作方法,文章通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08javascript中不提供sleep功能如何實(shí)現(xiàn)這個(gè)功能
javascript中不提供sleep功能,而我們時(shí)長(zhǎng)會(huì)用到這個(gè)功能,下面與大家分享個(gè)不錯(cuò)的解決方法,而且在不同的機(jī)器上的執(zhí)行速度是一致的2014-05-05JS實(shí)現(xiàn)的自動(dòng)打字效果示例
這篇文章主要介紹了JS實(shí)現(xiàn)的自動(dòng)打字效果,涉及javascript遞歸算法、字符串操作及事件函數(shù)相關(guān)使用技巧,需要的朋友可以參考下2017-03-03JavaScript中while循環(huán)的基礎(chǔ)使用教程
這篇文章主要給大家介紹了關(guān)于JavaScript中while循環(huán)的基礎(chǔ)使用教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08才發(fā)現(xiàn)的超鏈接js導(dǎo)致網(wǎng)頁(yè)中GIF動(dòng)畫停止的解決方法
才發(fā)現(xiàn)的超鏈接js導(dǎo)致網(wǎng)頁(yè)中GIF動(dòng)畫停止的解決方法...2007-11-11JavaScript之Blob對(duì)象類型的具體使用方法
這篇文章主要介紹了JavaScript之Blob對(duì)象類型的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11