ios 基于CTMediator的組件化搭建歷程

需求前提:希望App由多個業(yè)務(wù)組件組裝起來奋岁,每個業(yè)務(wù)模塊都可單獨成為子App嚼酝。
解耦妄均,快速開發(fā)毙驯!

流程

  1. 創(chuàng)建遠(yuǎn)程私有庫
  2. 創(chuàng)建業(yè)務(wù)組件項目xxx倒堕,并同步到私有庫
  3. 創(chuàng)建組件與外界聯(lián)系媒介xxx_Category項目并同步遠(yuǎn)端倉庫
  4. 編寫代碼
  5. 主項目Podfile本地引用組件項目,并使項目編譯通過.
  6. 將本地引用改為遠(yuǎn)程引用,運行項目并編譯成功,組件化完成.

搭建項目

1.創(chuàng)建遠(yuǎn)程私有庫

  • github上開了一個orgnization
  • 在orgnization中創(chuàng)建私有pod源倉庫,命名為XXXPod(用來存放后面打包的私有庫)
  • 在orgnization中創(chuàng)建業(yè)務(wù)組件項目xxx遠(yuǎn)程倉庫
  • 在orgnization中創(chuàng)建業(yè)務(wù)組件項目xxx與外界聯(lián)系媒介xxx_Category遠(yuǎn)程倉庫

如果有多個便創(chuàng)建多個倉庫爆价,目錄如下:


·

2. 創(chuàng)建業(yè)務(wù)組件項目

cd 項目存放目錄
//創(chuàng)建組件項目
pod lib create xxx
  • 根據(jù)提示輸入


    image.png
  • 得到如下工程:
    Class:存放組件對外接口
    Assets:存放資源


    image.png
  • 同步代碼到github上(這里就不做多說了)

3.創(chuàng)建組件與外界聯(lián)系媒介xxx_Category項目及遠(yuǎn)端倉庫

cd 項目存放目錄
//創(chuàng)建組件項目
pod lib create xxx_Category
  • 根據(jù)提示輸入


    image.png
  • 得到如下工程


    image.png
  • 同步代碼到github上

4.編寫組件工程代碼

以跳轉(zhuǎn)到ExampleViewController為例

1.創(chuàng)建ExampleViewController并編寫需要的業(yè)務(wù)代碼
2.創(chuàng)建Target_Business1(后面會說明為何這么命名)用以跳轉(zhuǎn)到ExampleViewController
@interface Target_Business1 : NSObject

- (UIViewController *)Action_viewController:(NSDictionary *)params;

@end




#import "Target_Business1.h"
#import "ExampleViewController.h"

@implementation Target_Business1

- (UIViewController *)Action_viewController:(NSDictionary *)params
{
    ExampleViewController *viewController = [[ExampleViewController alloc] init];
    viewController.title = params[@"title"];//以設(shè)置title為例
    return viewController;
}

@end

將業(yè)務(wù)代碼文件及Target_Business1文件拖入class文件夾重新pod update, 運行成功即可垦巴!在這里可以在Example demo中寫個接口跳轉(zhuǎn)到業(yè)務(wù)代碼頁面進(jìn)行調(diào)試!

5.編寫xxx_Category中的對外代碼

注意xxx_Category需要依賴CTMediator,在 XXX_Category.podspec文件中添加依賴:

s.dependency 'CTMediator'

創(chuàng)建對外聯(lián)系接口文件CTMediator+XXX

#import <CTMediator/CTMediator.h>

NS_ASSUME_NONNULL_BEGIN

@interface CTMediator (BUSINESS1_CATEGORY)

- (UIViewController *)toBusiness1WithParam:(NSDictionary *)param;

@end

NS_ASSUME_NONNULL_END


@implementation CTMediator (BUSINESS1_CATEGORY)

- (UIViewController *)toBusiness1WithParam:(NSDictionary *)param{
    return [self performTarget:@"Business1" action:@"viewController" params:param shouldCacheTarget:NO];
}

@end

這里用到的performTarget方法我們可以點擊進(jìn)去查看源碼铭段,可以看到固定寫法Target_XXX骤宣,所以在之前我們創(chuàng)建了命名為Target_XXX的文件!

運行成功后將CTMediator+XXX拖入Classes文件夾序愚,重新pod update憔披,運行!

6. 將兩個組件項目復(fù)制到主項目工程目錄中,在Podfile中引用組件

  pod 'Business1',:path => 'Business1'
  pod 'Business1_Category',:path => 'Business1_Category'

pod update 運行成功即可
image.png

7. 主項目工程中引用

#import <CTMediator+BUSINESS1_CATEGORY.h>
UIViewController *viewController = [[CTMediator sharedInstance] toBusiness1WithParam:@{@"title":@"業(yè)務(wù)1"}];
        [self.navigationController pushViewController:viewController animated:YES];

8. 將本地引用改為遠(yuǎn)程引用

  1. 進(jìn)入私有庫工程找到XXX.podspec芬膝,并根據(jù)具體需要修改望门,如:
    image.png
  2. 將組件代碼都push到遠(yuǎn)程庫
  3. 上傳到我們的私有pod源倉庫(也就是第一步我們創(chuàng)建的私有pod源倉庫)
cd 到私有庫文件

git tag 0.1.0(注意,這里的tag必須和.podSpec文件的版本一致)

git push --tags

pod repo add 源倉庫名稱 源倉庫遠(yuǎn)程地址(第一步創(chuàng)建的私有pod源倉庫地址)
如:pod repo add ConfigPrivatePod https://github.com/Baffin-TM/ConfigPrivatePod.git

這樣我們可以在.cocoapods中看到:
image.png

再執(zhí)行:

pod repo push ConfigPrivatePod Business1.podspec --allow-warnings

可以看到github源倉庫ConfigPrivatePod以及本地.cocoapods中的ConfigPrivatePod將會將會多出一個文件:


image.png

image.png
  1. 同上锰霜,將Business1_Category上傳到遠(yuǎn)程私有庫
git tag 0.1.0  
git push --tags
#無需在pod repo add 源倉庫名稱 源倉庫遠(yuǎn)程地址
pod repo push ConfigPrivatePod Business1_Category.podspec --allow-warnings

9. Podfile引用遠(yuǎn)程組件

#一定要加遠(yuǎn)程索引庫地址
source 'https://github.com/Baffin-TM/ConfigPrivatePod.git'
source 'https://github.com/CocoaPods/Specs.git'

pod 'Business1'
pod 'Business1_Category'

pod update 運行成功即可

10. 更新庫

1.組件中podspec文件把版本提高一個

2.提交代碼到遠(yuǎn)端庫,打上tag,tag和podspec文件里面版本一樣

3.pod repo push 源倉庫名稱 XXX.podspec --allow-warnings

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末筹误,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子癣缅,更是在濱河造成了極大的恐慌厨剪,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件友存,死亡現(xiàn)場離奇詭異祷膳,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)屡立,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進(jìn)店門钾唬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人侠驯,你說我怎么就攤上這事抡秆。” “怎么了吟策?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵儒士,是天一觀的道長。 經(jīng)常有香客問我檩坚,道長着撩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任匾委,我火速辦了婚禮拖叙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘赂乐。我一直安慰自己薯鳍,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布挨措。 她就那樣靜靜地躺著挖滤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪浅役。 梳的紋絲不亂的頭發(fā)上斩松,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天,我揣著相機(jī)與錄音觉既,去河邊找鬼惧盹。 笑死乳幸,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钧椰。 我是一名探鬼主播反惕,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼演侯!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起背亥,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤秒际,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后狡汉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體娄徊,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年盾戴,在試婚紗的時候發(fā)現(xiàn)自己被綠了寄锐。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡尖啡,死狀恐怖橄仆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情衅斩,我是刑警寧澤盆顾,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站畏梆,受9級特大地震影響您宪,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜奠涌,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一宪巨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧溜畅,春花似錦捏卓、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至峦椰,卻和暖如春龄寞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背汤功。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工物邑, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓色解,卻偏偏與公主長得像茂嗓,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子科阎,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容