JS 的應(yīng)用開發(fā)初探(mootools)
更新時間:2009年12月19日 01:17:47 作者:
昨天在公司內(nèi)部做了一個小小的技術(shù)分享,就 js 應(yīng)用開發(fā)方面跟大家談了一點(diǎn)自己的心得,最近因?yàn)楣ぷ麝P(guān)系花在這上面的時間較多也頗有些收獲,寫在這里備忘。
做了三個小demo,本來想做一個類似Gmail的界面出來后來突然發(fā)現(xiàn)機(jī)器上沒有Office,就干脆做了一個類PPT演示的小玩意。
基于js的應(yīng)用開發(fā)總結(jié)起來主要有如下幾點(diǎn):
封裝粒度
常用功能封裝為可重復(fù)使用的組件,需要合理選擇組件封裝粒度,粒度過大不便于復(fù)用,粒度過小則得不償失。
代碼結(jié)構(gòu)規(guī)劃
吸收傳統(tǒng)軟件開發(fā)的思想將代碼按功能劃分為不同的區(qū)塊:初始化,事件綁定,事件邏輯處理,外部Callback調(diào)用
Js的面向?qū)ο?
簡單起見可以使用構(gòu)造函數(shù)(其實(shí)就是普通的Function)+ prototype定義,雖然看起來不是很優(yōu)雅不過卻是比較直接的解決辦法。演示代碼中使用了Mootools類庫,相比jQuery來說,這個類庫的面向?qū)ο筇匦允褂闷饋韨€人感覺更好一些,當(dāng)然也可以使用它自帶的Class申明方式來編寫你自己的Class:
Meta.Controls.Pager = new Class({
Implements: [Events, Options],
options: {
pageIndex :1, // 當(dāng)前頁碼, 從1開始
size : 10, // 每頁顯示記錄數(shù)
maxButtons : 5,// 顯示的分頁按鈕數(shù)量
showPageSize:true, // 顯示分頁大小選項(xiàng).
sizeArray:[10, 25]
},
initialize: function (A) {
this.setOptions(A);
this.pageIndex = this.options.pageIndex;
this.size = this.options.size;
this.maxButtons = this.options.maxButtons;
this.itemCount = 0;
this.pageCount =0 ;
},
......
}
這樣的方式也是不錯的選擇,代碼邏輯結(jié)構(gòu)清晰一目了然。
單元測試
通常認(rèn)為瀏覽器上的js 應(yīng)用要做單元測試不好做,原因主要是跟DOM關(guān)系太緊密,但也不是完全沒有辦法,比如Google的Closure就做得不錯,使用Mock的對象來模擬Dom元素并解耦代碼邏輯與Dom對象操作。
下面是本次實(shí)例的代碼,感興趣的童鞋自行下載。
基于js的應(yīng)用開發(fā)總結(jié)起來主要有如下幾點(diǎn):
封裝粒度
常用功能封裝為可重復(fù)使用的組件,需要合理選擇組件封裝粒度,粒度過大不便于復(fù)用,粒度過小則得不償失。
代碼結(jié)構(gòu)規(guī)劃
吸收傳統(tǒng)軟件開發(fā)的思想將代碼按功能劃分為不同的區(qū)塊:初始化,事件綁定,事件邏輯處理,外部Callback調(diào)用
Js的面向?qū)ο?
簡單起見可以使用構(gòu)造函數(shù)(其實(shí)就是普通的Function)+ prototype定義,雖然看起來不是很優(yōu)雅不過卻是比較直接的解決辦法。演示代碼中使用了Mootools類庫,相比jQuery來說,這個類庫的面向?qū)ο筇匦允褂闷饋韨€人感覺更好一些,當(dāng)然也可以使用它自帶的Class申明方式來編寫你自己的Class:
復(fù)制代碼 代碼如下:
Meta.Controls.Pager = new Class({
Implements: [Events, Options],
options: {
pageIndex :1, // 當(dāng)前頁碼, 從1開始
size : 10, // 每頁顯示記錄數(shù)
maxButtons : 5,// 顯示的分頁按鈕數(shù)量
showPageSize:true, // 顯示分頁大小選項(xiàng).
sizeArray:[10, 25]
},
initialize: function (A) {
this.setOptions(A);
this.pageIndex = this.options.pageIndex;
this.size = this.options.size;
this.maxButtons = this.options.maxButtons;
this.itemCount = 0;
this.pageCount =0 ;
},
......
}
這樣的方式也是不錯的選擇,代碼邏輯結(jié)構(gòu)清晰一目了然。
單元測試
通常認(rèn)為瀏覽器上的js 應(yīng)用要做單元測試不好做,原因主要是跟DOM關(guān)系太緊密,但也不是完全沒有辦法,比如Google的Closure就做得不錯,使用Mock的對象來模擬Dom元素并解耦代碼邏輯與Dom對象操作。
下面是本次實(shí)例的代碼,感興趣的童鞋自行下載。
您可能感興趣的文章:
- JavaScript+CSS實(shí)現(xiàn)仿Mootools豎排彈性動畫菜單效果
- JS實(shí)現(xiàn)Fisheye效果動感放大菜單代碼
- JS+CSS實(shí)現(xiàn)的經(jīng)典圓角下拉菜單效果代碼
- JS實(shí)現(xiàn)帶有3D立體感的銀灰色豎排折疊菜單代碼
- JS實(shí)現(xiàn)的左側(cè)豎向滑動菜單效果代碼
- JS+CSS實(shí)現(xiàn)另類帶提示效果的豎向?qū)Ш讲藛?/a>
- JS實(shí)現(xiàn)的簡潔二級導(dǎo)航菜單雛形效果
- JS+CSS相對定位實(shí)現(xiàn)的下拉菜單
- JS實(shí)現(xiàn)的仿東京商城菜單、仿Win右鍵菜單及仿淘寶TAB特效合集
- JS基于Mootools實(shí)現(xiàn)的個性菜單效果代碼
相關(guān)文章
淺析javascript中函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別
這篇文章主要介紹了淺析javascript中函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別,需要的朋友可以參考下2015-02-02一個JavaScript獲取元素當(dāng)前高度的實(shí)例
這篇文章主要為大家介紹了一個JavaScript獲取元素當(dāng)前高度的實(shí)例,比較實(shí)用,建議新手朋友們可以看看2014-10-10JS實(shí)現(xiàn)多張圖片預(yù)覽同步上傳功能
這篇文章主要介紹了JS實(shí)現(xiàn)多張圖片預(yù)覽同步上傳功能的相關(guān)資料,需要的朋友可以參考下2017-06-06javascript嚴(yán)格模式詳解(含嚴(yán)格模式與非嚴(yán)格模式的區(qū)別)
這篇文章主要介紹了javascript嚴(yán)格模式詳解(含嚴(yán)格模式與非嚴(yán)格模式的區(qū)別),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11JavaScript程序員應(yīng)該知道的45個實(shí)用技巧
在這篇文章中,我將分享一組JavaScript的技巧、竅門和最佳實(shí)踐,這些都是JavaScript程序員應(yīng)該知曉的,不管他們是使用在瀏覽器/引擎上,還是服務(wù)器端(SSJS——Service Side JavaScript)JavaScript解釋器上2014-03-03