1.組件化有什么好處锅很?
業(yè)務(wù)分層凤跑、解耦叛复,使代碼變得可維護(hù);
有效的拆分咖耘、組織日益龐大的工程代碼撬码,使工程目錄變得可維護(hù);
便于各業(yè)務(wù)功能拆分呜笑、抽離,實(shí)現(xiàn)真正的功能復(fù)用凰慈;
業(yè)務(wù)隔離驼鹅,跨團(tuán)隊(duì)開發(fā)代碼控制和版本風(fēng)險控制的實(shí)現(xiàn)森篷;
模塊化對代碼的封裝性豺型、合理性都有一定的要求,提升開發(fā)同學(xué)的設(shè)計(jì)能力钓辆;
在維護(hù)好各級組件的情況下哼绑,隨意組合滿足不同客戶需求;(只需要將之前的多個業(yè)務(wù)組件模塊在新的主App中進(jìn)行組裝即可快速迭代出下一個全新App)
2.你是如何組件化解耦的蛀恩?
-
分層
基礎(chǔ)功能組件:按功能分庫茂浮,不涉及產(chǎn)品業(yè)務(wù)需求,跟庫Library類似顽馋,通過良好的接口拱上層業(yè)務(wù)組件調(diào)用幌羞;不寫入產(chǎn)品定制邏輯,通過擴(kuò)展接口完成定制属桦;
基礎(chǔ)UI組件:各個業(yè)務(wù)模塊依賴使用聂宾,但需要保持好定制擴(kuò)展的設(shè)計(jì)
業(yè)務(wù)組件:業(yè)務(wù)功能間相對獨(dú)立,相互間沒有Model共享的依賴系谐;業(yè)務(wù)之間的頁面調(diào)用只能通過UIBus進(jìn)行跳轉(zhuǎn);業(yè)務(wù)之間的邏輯Action調(diào)用只能通過服務(wù)提供鄙煤;
中間件:target-action茶袒,url-block,protocol-class
3.為什么CTMediator方案優(yōu)于基于Router的方案乾巧?
Router的缺點(diǎn):
在組件化的實(shí)施過程中,注冊URL并不是充分必要條件咳胃。組件是不需要向組件管理器注冊URL的旷太,注冊了URL之后,會造成不必要的內(nèi)存常駐供璧。注冊URL的目的其實(shí)是一個服務(wù)發(fā)現(xiàn)的過程睡毒,在iOS領(lǐng)域中,服務(wù)發(fā)現(xiàn)的方式是不需要通過主動注冊的演顾,使用runtime就可以了。另外葛虐,注冊部分的代碼的維護(hù)是一個相對麻煩的事情棉钧,每一次支持新調(diào)用時,都要去維護(hù)一次注冊列表摄悯。如果有調(diào)用被棄用了愧捕,是經(jīng)常會忘記刪項(xiàng)目的申钩。runtime由于不存在注冊過程,那就也不會產(chǎn)生維護(hù)的操作撒遣,維護(hù)成本就降低了义黎。 由于通過runtime做到了服務(wù)的自動發(fā)現(xiàn),拓展調(diào)用接口的任務(wù)就僅在于各自的模塊廉涕,任何一次新接口添加,新業(yè)務(wù)添加宠纯,都不必去主工程做操作,十分透明快集。
在iOS領(lǐng)域里廉白,一定是組件化的中間件為openURL提供服務(wù),而不是openURL方式為組件化提供服務(wù)院溺。如果在給App實(shí)施組件化方案的過程中是基于openURL的方案的話晕讲,有一個致命缺陷:非常規(guī)對象(不能被字符串化到URL中的對象,例如UIImage)無法參與本地組件間調(diào)度弄息。 在本地調(diào)用中使用URL的方式其實(shí)是不必要的勤婚,如果業(yè)務(wù)工程師在本地間調(diào)度時需要給出URL,那么就不可避免要提供params缨称,在調(diào)用時要提供哪些params是業(yè)務(wù)工程師很容易懵逼的地方祝迂。
為了支持傳遞非常規(guī)參數(shù),蘑菇街的方案采用了protocol型雳,這個會侵入業(yè)務(wù)纠俭。由于業(yè)務(wù)中的某個對象需要被調(diào)用,因此必須要符合某個可被調(diào)用的protocol冤荆,然而這個protocol又不存在于當(dāng)前業(yè)務(wù)領(lǐng)域钓简,于是當(dāng)前業(yè)務(wù)就不得不依賴public Protocol汹想。這對于將來的業(yè)務(wù)遷移是有非常大的影響的芥被。
CTMediator的優(yōu)點(diǎn):
調(diào)用時,區(qū)分了本地應(yīng)用調(diào)用和遠(yuǎn)程應(yīng)用調(diào)用冗茸。本地應(yīng)用調(diào)用為遠(yuǎn)程應(yīng)用調(diào)用提供服務(wù)匹中。
組件僅通過Action暴露可調(diào)用接口,模塊與模塊之間的接口被固化在了Target-Action這一層挂绰,避免了實(shí)施組件化的改造過程中服赎,對Business的侵入,同時也提高了組件化接口的可維護(hù)性践付。
方便傳遞各種類型的參數(shù)缺厉。
4.基于CTMediator的組件化方案,有哪些核心組成提针?
CTMediator中間件:集成就可以了
模塊Target_%@:模塊的實(shí)現(xiàn)及提供對外的方法調(diào)用Action_methodName辐脖,需要傳參數(shù)時,都統(tǒng)一以NSDictionary*的形式傳入艇抠。
CTMediator+%@擴(kuò)展:擴(kuò)展里聲明了模塊業(yè)務(wù)的對外接口炭剪,參數(shù)明確翔脱,這樣外部調(diào)用者可以很容易理解如何調(diào)用接口。