這篇文章將為大家詳細(xì)講解有關(guān)Flex框架中Cairngorm和Mate的優(yōu)缺點是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的柳北網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
如何選擇一個Flex框架
Cairngorm
Cairngorm是一個廣為人知的老牌Flex框架。它是一個微型架構(gòu)——由一些設(shè)計模式組成用來降低團隊協(xié)作的困難。
Cairngorm從Java的世界帶來了很多開發(fā)理念,并且把重點放在三個關(guān)鍵區(qū)域:處理用戶動作,封裝服務(wù)端的交互和業(yè)務(wù)邏輯,管理客戶端的狀態(tài)和界面呈現(xiàn)。
使用Cairngorm來構(gòu)建一個項目,需要將應(yīng)用代碼分離到不同的包并且繼承Cairngorm的類。以下是Cairngorm項目中一些主要的部分和類。
ModelLocator是一個儲存數(shù)據(jù)的單例,數(shù)據(jù)表示程序的狀態(tài)。單例類的性質(zhì)保證了程序中的所有組件取得的是相同的數(shù)據(jù)。
ServiceLocator是另一個單例,它集中管理所有服務(wù)如HTTPServices。同樣,由于是單例,程序中的所有組件取得的是相同的服務(wù)。
業(yè)務(wù)邏輯被封裝在command類中。command實現(xiàn)了命令模式,它們表示相應(yīng)用戶事件的邏輯。
事件被類FrontController處理,F(xiàn)rontController會把事件映射到相應(yīng)的Command。
Delegate類作為代理來對遠端服務(wù)進行請求和響應(yīng)。
優(yōu)點
Cairngorm在Flex社區(qū)廣為人知,作為Adobe開源項目的一員,擁有活躍的社區(qū)和開發(fā)者的支持。
其次,該框架吸取了Java開發(fā)中許多寶貴的經(jīng)驗,并成功得用于大型項目的開發(fā)中。
并且,Cairngorm適用于團隊開發(fā),因為它提供了結(jié)構(gòu)化的開發(fā)方法來創(chuàng)建應(yīng)用,利于分布式的開發(fā)。
缺點
需要寫大量的類應(yīng)該是Cairngorm最多的負(fù)面評論了。在Cairngorm中,每一個event對應(yīng)一個command;因此,需要對程序觸發(fā)的每一個事件來寫一個command類。而且,還要為command寫一些其他的類,例如delegates。即使是一個中型的應(yīng)用也會導(dǎo)致大量的類產(chǎn)生。
其次,Cairngorm實現(xiàn)了自己的一套事件處理的方法。這增加了Flex內(nèi)置事件模型的復(fù)雜度,而且它還有限制。由于每個事件都有自己的的command,事件的響應(yīng)者被限制成1個。加之Cairngorm的事件不具冒泡特性,如果要發(fā)送數(shù)據(jù)到容器的其它層次則需要自己來實現(xiàn)。
第三個常見的批評是Cairngorm依賴全局的單例,這讓模塊和單元測試變得困難。盡管可以打破單例中的模型簡化測試,但是會增加額外的過程。
資源
Cairngormdeveloperdocumentation
DevelopingFlexRIAswithCairngormmicroarchitecture–Part1:IntroducingCairngorm(StevenWebsterandLeonTanner,August2008)
ExampleCairngormproject
Mate
Mate是一個基于標(biāo)簽的,事件驅(qū)動的Flex框架。基于標(biāo)簽意味著它可以完全實現(xiàn)在MXML中。該框架的目的是讓事件響應(yīng)者的聲明變得簡便。
在項目中使用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一樣為每個事件都使用單獨的響應(yīng)。Mate的MXML標(biāo)簽文件簡單易用,而且文檔優(yōu)秀,在官網(wǎng)上有大量的代碼實例。
缺點
Mate使用MXML文件構(gòu)建,要是作為一個ActionScript開發(fā)者,就需要調(diào)整自己的習(xí)慣。而且Mate沒有為應(yīng)用程序制定結(jié)構(gòu),這份工作留給了開發(fā)者。
因此,需要加強團隊協(xié)作來保證代碼的兼容性。還有一個問題與AdobeLiveCycleDataServicesES有關(guān),要知道Mate暫時還不能處理LiveCycleDataServices提供的數(shù)據(jù)管理方面的功能。
關(guān)于“Flex框架中Cairngorm和Mate的優(yōu)缺點是什么”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。