Flex框架中Cairngorm和Mate的優(yōu)點大比拼
本文和大家重點討論一下Flex框架中Cairngorm和Mate的優(yōu)缺點,Cairngorm是一個廣為人知的老牌Flex框架,而Mate是一個基于標簽的,事件驅(qū)動的框架。它們有什么不同點或者相似之處嗎請看下文詳細介紹。
如何選擇一個Flex框架
Cairngorm
Cairngorm是一個廣為人知的老牌Flex框架。它是一個微型架構(gòu)——由一些設計模式組成用來降低團隊協(xié)作的困難。
Cairngorm從Java的世界帶來了很多開發(fā)理念,并且把重點放在三個關鍵區(qū)域:處理用戶動作,封裝服務端的交互和業(yè)務邏輯,管理客戶端的狀態(tài)和界面呈現(xiàn)。
使用Cairngorm來構(gòu)建一個項目,需要將應用代碼分離到不同的包并且繼承Cairngorm的類。以下是Cairngorm項目中一些主要的部分和類。
ModelLocator是一個儲存數(shù)據(jù)的單例,數(shù)據(jù)表示程序的狀態(tài)。單例類的性質(zhì)保證了程序中的所有組件取得的是相同的數(shù)據(jù)。
ServiceLocator是另一個單例,它集中管理所有服務如HTTPServices。同樣,由于是單例,程序中的所有組件取得的是相同的服務。
業(yè)務邏輯被封裝在command類中。command實現(xiàn)了命令模式,它們表示相應用戶事件的邏輯。
事件被類FrontController處理,F(xiàn)rontController會把事件映射到相應的Command。
Delegate類作為代理來對遠端服務進行請求和響應。
優(yōu)點
Cairngorm在Flex社區(qū)廣為人知,作為Adobe開源項目的一員,擁有活躍的社區(qū)和開發(fā)者的支持。
其次,該框架吸取了Java開發(fā)中許多寶貴的經(jīng)驗,并成功得用于大型項目的開發(fā)中。
并且,Cairngorm適用于團隊開發(fā),因為它提供了結(jié)構(gòu)化的開發(fā)方法來創(chuàng)建應用,利于分布式的開發(fā)。
缺點
需要寫大量的類應該是Cairngorm最多的負面評論了。在Cairngorm中,每一個event對應一個command;因此,需要對程序觸發(fā)的每一個事件來寫一個command類。而且,還要為command寫一些其他的類,例如delegates。即使是一個中型的應用也會導致大量的類產(chǎn)生。
其次,Cairngorm實現(xiàn)了自己的一套事件處理的方法。這增加了Flex內(nèi)置事件模型的復雜度,而且它還有限制。由于每個事件都有自己的的command,事件的響應者被限制成1個。加之Cairngorm的事件不具冒泡特性,如果要發(fā)送數(shù)據(jù)到容器的其它層次則需要自己來實現(xiàn)。
第三個常見的批評是Cairngorm依賴全局的單例,這讓模塊和單元測試變得困難。盡管可以打破單例中的模型簡化測試,但是會增加額外的過程。
資源
Cairngormdeveloperdocumentation
DevelopingFlexRIAswithCairngormmicroarchitecture–Part1:IntroducingCairngorm(StevenWebsterandLeonTanner,August2008)
ExampleCairngormproject
Mate
Mate是一個基于標簽的,事件驅(qū)動的Flex框架?;跇撕炓馕吨梢酝耆珜崿F(xiàn)在MXML中。該框架的目的是讓事件響應者的聲明變得簡便。
在項目中使用Mate只需要處理兩個方面:使用1個或者多個事件,有一個成為”eventmap“的MXML文件——被包含在主程序中的一個MXML文件。它定義了需要監(jiān)聽的事件以及如何被處理。必須有1個eventmap,而且允許有多個。
Mate也實現(xiàn)了依賴注入(Dependencyinjection)的理念——有時被稱為好萊塢原則,或“don’tcallus,we’llcallyou”。對象的創(chuàng)建時這樣一種方式:數(shù)據(jù)被創(chuàng)建并且注入到對象中。也就是說,對象不會喊著要數(shù)據(jù)(”don’tcallus”),而是數(shù)據(jù)被傳送給對象(”we’llcallyou”)。
優(yōu)點
Mate使用依賴注入提升了松耦合性。因為組件不依賴全局的單例,能更自由地作為對立的部分。Mate不會阻止你使用Flex內(nèi)建的事件機制,也不會像Cairngorm一樣為每個事件都使用單獨的響應。Mate的MXML標簽文件簡單易用,而且文檔優(yōu)秀,在官網(wǎng)上有大量的代碼實例。
缺點
Mate使用MXML文件構(gòu)建,要是作為一個ActionScript開發(fā)者,就需要調(diào)整自己的習慣。而且Mate沒有為應用程序制定結(jié)構(gòu),這份工作留給了開發(fā)者。
因此,需要加強團隊協(xié)作來保證代碼的兼容性。還有一個問題與AdobeLiveCycleDataServicesES有關,要知道Mate暫時還不能處理LiveCycleDataServices提供的數(shù)據(jù)管理方面的功能。
翻譯自:http://www.adobe.com/devnet/flex/articles/flex_framework_02.html
【編輯推薦】