Skip to main content

PureMVC 我也會 [2]

PureMVC Gestalt

• Model and Proxy
• View and Mediator
• Controller and Commands
• Facade and Core
• Observers and Notification


Facade
  1. 簡化一切,讓你只需要對一個窗口
  2. Standard version 的 Facade 是個單例
  3. Multi-core 版本是由單例的 Facade bus(Array) 控制
  4. Model, View and Controller 三個單例的總代理
  5. Commands, Mediators and Proxy 的註冊、取用與移除都是在這裡
  6. 反正就是想要操作其他 class 時,可以先參考 facade 一下...
  7. 開始寫 PureMVC 專案後,你會發現它無所不在,甩都甩不掉...

每個專案的 ApplicationFacade 都長得很像(當然命名可以修改,內容不太需要變動)。如果你有自己特有的 Singleton Class 寫法,請自行修改。懶得改的人就直接用它官網上範例的寫法即可,其實乖乖的用也不會變壞到哪去啦!
以下為標準的 ApplicationFacade 寫法:
PS:範例 code 皆使用 Standard 版本 + Flex SDK 3.x or 4.x 來呈現,也許不是完整的寫法,請勿真的照抄後執行

package com.mvc
{
import org.puremvc.as3.patterns.facade.Facade;
import org.puremvc.as3.interfaces.IFacade;
import mx.core.Application;
import com.mvc.controls.StartupCommand;

public class ApplicationFacade extends Facade implements IFacade
{
public static const STARTUP:String = 'startup';
public function ApplicationFacade()
{
super();
}
public static function getInstance() : ApplicationFacade
{
if ( instance == null ) instance = new ApplicationFacade( );
return instance as ApplicationFacade;
}

override protected function initializeController( ) : void
{
super.initializeController();
registerCommand( STARTUP , StartupCommand );
}

public function startup( app:Application ) : void
{
sendNotification( STARTUP, app );
}
}
}


初始化 Facade

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
width="220" height="200" layout="absolute"
applicationComplete="ApplicationFacade.getInstance().startup( this )" >

<mx:List id="list"/>
</mx:Application>



ApplicationFacade.getInstance().startup( this ) // 就是這句...


ApplicationFacade 先繼承 Facade, 做的事情就是提供一個唯一的實體,再來註冊 string key "STARTUP" 的 Command (當然這個 StartupCommand 接下來會寫出來 ),接著就是發送通知(sendNotification) "STARTUP" ,順便將傳入的 app:Application 送出去...end... 真簡單對吧?

在 Proxy, Command and Mediator 要取用 Facade 怎麼辦?難道用 var facade:ApplicationFacade = ApplicationFacade.getInstance(); 來引用嗎?當然不可能!就說你甩不掉它了,因為這基本上常用到的 Class 都會帶著一個名為 「facade」 的屬性,直接用就可以囉!

其實你要註冊一堆相關 Proxy, Command, Mediator 都可以直接寫在 ApplicationFacade,為什麼它還要分離出去將初始化寫在 StartupCommand 內?這就是程式的藝術了。與其專案開發時增增減減不斷的改寫這個檔案, 到不如快快樂樂的用不同的 Command 來處理初始豈不是更乾淨?尤其專案通常是多人開發,人多手雜蟲蟲翩飛的道理不懂嗎?XD

Facade 可以用的 function 簡單到翻臉,國中英文有學好的應該都沒問題。
PureMVC AS3 API Doc - Facade
常用還是這幾個 register(註冊), remove(刪除), retrieve(取回)has(有沒有) 系列 function。

Facade 就先到此為止囉!

Comments

Popular posts from this blog

[Flex] PureMVC standard with Spring extensions

由於上次稍微玩了一下 Robotlegs 依賴注入(DI) 主導的 MVC 框架,而著名也使用依賴注入的 Java / Java EE 的 Spring framework 出了 for ActionScript 的版本,剛好在最近 Spring ActionScript 1.0 正式 release 了(想了解 Spring 是啥咪東東的話請自行找 google 大神),這個版本除了基本框架外,也包含了 Cairngorm 與 PureMVC 的外掛...想當然耳,就拿來測試一下用在 PureMVC 內的感覺囉!! 參考了 官方範例 中 PureMVC 唯二的範例原始檔,以下使用的是「設定檔依賴注入 facade 透過 addConfigSource() 的方式來 init 」:(其實除了 embed 外,都是外部載入) Online Demo with source code 工作環境:FlashBuilder, Flex SDK4 請下載 PureMVC Standard 版本 再下載 Spring ActionScript 最新版本後,除了 spring-actionscript-cairngorm 不需要外,都放到 /src 下(記得只需要 org 開始...),也別忘了lib 內的 swc 檔 copy 到 /libs 下 Spring 的 injection 並不像 Robotlegs 直接來個 [Inject] metadata 的自動化那樣方便,但是其冷血度(檔案的鬆偶程度)更勝後者!如果你要使用設定檔(applicationContext.xml) 來做注入的話,準備工作就挺多的...XD 依照 applicationContext.xml 內設定的方式分別寫入 constructor 或者是 setter 依賴注入(本範例統一使用 setter injection) 為了跟大家都沒關係所以都使用 interface 來處理,所以你會在範例中發現大家都有介面...(並沒有真的研究過 Spring,也許還有其他作法) 準備 compiler 時候要用的 classe。由於在 setter, getter 的寫法上都使用 interface,所以真正用到的 class 需要預先在輸出階段就打包到程式內。 基本上 PureMVC 類 class...

[543] 最近的 Erin 在做什麼?

最近 Erin 噗浪玩很大,都忘了要寫 blog... 自從四月初開始認真當 SOHO 後,每天都過著"醉生夢死"的生活...?? 目前的行程: 五六月 - 滿檔中... 七月( 每週一三晚間 ) - 授課 飛肯 ActionScript 3.0 & XML 資料庫整合應用班 (會準備什麼隱藏課程?你來了就知道...XD ) 七八九月 - 短期約聘面談中 十月 - 等你聯絡囉~~^^ 近期如果你有"不急的" Flex / AIR / Flash / Flash lite 相關的案子需要外發都可以直接與我聯絡!也接受短期約聘喔! 1 ) 如何聯絡 Erin? 寄 e-mail 是最快的喔!不然可以透過 blog 上的 Plugoo 視窗與我聯絡,再來就是噗浪...XD E-mail: erinylin [at] gmail [dot] com Plurk: http://www.plurk.com/erinlin 2 ) 為什麼不公開留 MSN...?? 嗯...因為 Erin 記憶不好,外加 MSN 一堆幾百年沒有聯絡的朋友名單...所以還是先透過 e-mail 聯絡一下再加入比較記得... 3 ) Erin 到底會什麼? 啊...這個問題就有點難回答了,Erin 古早以前是個美術設計師,也當過電腦兼職講師,後來轉職當互動工程師,現在主要是做 AS1/AS2/AS3 "都可以"的前端互動開發(程式為主)。凡舉 Flex / AIR / Flash / Flash lite 相關的案子都做過,整合過很多專案,動畫也製作過(人物設定+動畫製作),在手機產業界接觸了 UI 設計與 UE 研究,最近經手的案子有國外活動網站(AS3+pv3D)中文化,公司進銷存系統網路化(Flex)...所以 Erin 到底能做什麼?嗯...就等你來研究囉~~ 4 ) 為什麼沒有作品集可以看? 這個就要問問為什麼一堆公司都要你簽 NDA (保密協定) ,搞的 Erin 也懶得公開經手過的作品,所以想要看到 Erin 做過什麼,就請記得找 Erin 面談時要註明『請帶電腦』這四個字 =) 裏 1 ) 目前 Erin 缺什麼? 嗯...缺男人(咦?這才是這篇的重點嗎?)