組件化簡介
想要做組件化的前提當(dāng)然得知道什么是組件化息拜。顧名思義廉丽,組件化就是將APP拆分成各個組件(或者說模塊也行)缠黍,同時解除這些模塊之間的耦合弄兜,然后通過主工程將項目所需要的組件組合起來十气。這樣組件化過后的項目就變成了很多小模塊猜年,如果新項目中有類似的需求绢片,直接將模塊引入稍作修改就能使用了焦履。
這種設(shè)計是不是很像引入三方庫做快速開發(fā)?其實制作組件的過程就相當(dāng)于做二方庫视卢。因此常見的組件化方案大多都是使用cocoapods做依賴管理踱卵。
優(yōu)點:
- 降低耦合度。組件化抽取出來是一個模塊据过,可以直接用pods進行管理的惋砂;
- 組件單獨開發(fā),單獨測試蝶俱。每個模塊都可以由專門維護的人去進行單獨開發(fā)班利,開發(fā)測試過程中饥漫,可以只編譯自己那部分代碼榨呆,不需要編譯整個項目代碼。
- 組件化后項目的代碼結(jié)構(gòu)更加清晰庸队,維護更加方便快捷积蜻;
- 適合多人協(xié)助開發(fā)。各自負責(zé)維護各自的模塊彻消,明確團隊開發(fā)的業(yè)務(wù)邊界竿拆,增加團隊協(xié)作效率。
缺點:
- 增加了代碼的冗余宾尚;
- 增加了項目的復(fù)雜度丙笋;
- 版本同步問題。
組件化拆分:
- 基礎(chǔ)組件拆分(宏定義煌贴、分類御板、工具類...)
- 功能拆分(數(shù)據(jù)庫、網(wǎng)絡(luò)框架牛郑、圖片加載...)
- 業(yè)務(wù)拆分(登錄怠肋、聊天、商城淹朋、社區(qū)...)
- Router(負責(zé)模塊之間的業(yè)務(wù)往來)
具體關(guān)于組件化方面的解釋請參考鏈接以下
利用cocoapods創(chuàng)建基于git的私有庫Spec Repo笙各,我這里以創(chuàng)建PSGTools為例
首先說一下本地私有庫的實現(xiàn)
打開終端,cd到需要存放的目錄下础芍,pod lib create PSGTools杈抢,出現(xiàn)Cloning https://github.com/CocoaPods/pod-template.git
into PSGTools
.,然后等待幾分鐘仑性,依次回答以下問題春感。
What is your name?
>這里輸入名字,可以隨便輸
What is your email?
>這里最好是輸入你gitee.com注冊的郵箱
What platform do you want to use?? [ iOS / macOS ]
>iOS
What language do you want to use?? [ Swift / ObjC ]
>ObjC
Would you like to include a demo application with your library? [ Yes / No ]
>Yes
Which testing frameworks will you use? [ Specta / Kiwi / None ]
>None
Would you like to do view based testing? [ Yes / No ]
>No
輸入完成之后就會自動創(chuàng)建這么一個工程。編譯PSGTools工程颂翼,如果導(dǎo)入的文件還依賴于第三方庫晃洒,在podfile文件中添加需要的三方庫并pod install即可,工程編譯通過就OK了朦乏。
然后在主項目中的podfile文件中添加
pod 'PSGTools', :path => 'PSGTools所在的目錄'
終端執(zhí)行pod install球及,就能看到主項目中多了以下依賴如果主項目中有重復(fù)的文件,需要刪除主項目中的重復(fù)文件呻疹,然后編譯運行通過就可以了吃引,這樣本地的就已經(jīng)弄好了。
本地私有庫和遠端的連接(我這里使用的是碼云的遠端庫管理)
-
選擇新建倉庫刽锤,倉庫名稱要與本地私有庫一直镊尺,我這里是PSGTools,然后選擇勾選私有并思,下面有勾選使用什么進行初始化庐氮,一個都不要勾選,點擊創(chuàng)建宋彼,然后就可以看到以下命令行教程弄砍,我們選擇已有倉庫的命令行進行操作。
- 依照已有倉庫命令行進行操作输涕,打開終端音婶,cd到私有庫的目錄下
cd xxxxx/PSGTools
輸入
git remote add origin https://gitee.com/xxxx/xxx.git
再輸入
git push -u origin master
- 刷新碼云界面就可以看到已經(jīng)上傳上去了,但是這還沒完占贫,我們看到碼云上面的PSGTools/Classes/目錄下還是只有ReplaceMe.m文件桃熄,說明在終端并沒有提交我們修改過的內(nèi)容,繼續(xù)回到終端執(zhí)行以下命令
git add .
git commit -m '這里輸入你要的提示的內(nèi)容型奥,例如:初始化'
git push origin master
這樣我們就能在碼云的Classes/目錄下看到我們需要的內(nèi)容了瞳收。
-
打開PSGTools.podspec文件,然后修改以下相對應(yīng)的內(nèi)容
然后進入終端在PSGTools目錄下對框架打tag標(biāo)簽厢汹,要對應(yīng).podspec里面的s.version
cd xxxxx/PSGTools
git tag 0.1.0
git push --tags
- 以上所有事情都做完了以后螟深,剩下的就是將私有庫的.podspec文件上傳到本地Spec Repo。
這里要說一下Spec Repo
看到上面文件夾顯示烫葬,repos目錄下默認只有master文件夾的界弧,在終端中輸入命令"pod repo"可以看到對應(yīng)的master凡蜻。
- 現(xiàn)在我們需要使用自己的Repo管理自己的私有庫框架,創(chuàng)建步驟如下
- 到碼云平臺創(chuàng)建一個新的倉庫垢箕,例如PSGSpec划栓,就可以拿到倉庫地址:https://gitee.com/PSG/PSGSpec.git
- 然后在終端輸入以下命令
pod repo add [Private Repo Name] [GitHub HTTPS clone URL]
[Private Repo Name] 是你本地需要用來管理私有庫的spec名稱 [GitHub HTTPS clone URL]是你新建的這個管理私有庫的倉庫地址 例如:pod repo add PSGSpec https://gitee.com/PSG/PSGSpec.git
- 這樣就成功的創(chuàng)建了私有庫管理倉庫,可以到home目錄下的/.cocoapods/repos目錄下看到對應(yīng)私有庫名稱的文件夾了条获,在終端使用"pod repo"命令也可以看到相對應(yīng)的文件名稱
- 私有庫管理倉庫創(chuàng)建好了之后就可以將私有庫的.podspec文件上傳到私有庫管理倉庫了
- 先驗證.podspec文件是否可用忠荞,如果有任何WARNING或者ERROR都是不可以的,它就不能被添加到Spec Repo中帅掘,不過xcode的WARNING是可以存在的委煤,驗證需要執(zhí)行一下命令
pod lib lint 避免警告pod lib lint --allow-warnings
- 再驗證遠程倉庫,驗證需要執(zhí)行一下命令
pod spec lint --allow-warnings
- 最后提交.podspec文件到倉庫
pod repo push PSGSpec PSGTools.podspec --allow-warnings
這樣私有庫的創(chuàng)建和配置就已經(jīng)完成了修档,到主項目中的podfile文件中將
pod 'PSGTools', :path => '../iOS組件/PSGTools'
修改成
pod 'PSGTools', '~> 0.1.0'
然后在終端cd到工程目錄下進行"pod install"
- 這里在使用"pod install"的時候會出現(xiàn)下面這種錯誤
PSGUI$ pod install Analyzing dependencies [!] Unable to find a specification for `PSGUtils (~> 0.1.0)`
打開終端執(zhí)行pod repo癣诱,就可以看到我們的私有庫管理庫Spec Repo计维,master是cocoapods默認的袜香,其他的就是我們自己創(chuàng)建的私有庫撕予,這里我的私有庫資源庫的地址是
https://gitee.com/G_Q/PSGSpec.git
在podfile文件中添加以下內(nèi)容
source 'https://gitee.com/xxxx/xxxx.git'
source 'https://github.com/CocoaPods/Specs.git'
例如我這里是這樣子的這里為什么寫上了自己的私有庫地址之后還得加上cocoapods原有的庫地址呢?因為如果加上了自己的資源地址之后蜈首,就只會在你添加的資源地址里面去尋找資源实抡,但是我們項目開發(fā)中除了使用自己的私有庫之外,經(jīng)常還要使用到GitHub上面的公開庫資源欢策,所以要配上Github公開庫資源地址吆寨。另外,如果我們有需要其他小伙伴的私有庫資源踩寇,就需要再加上其他小伙伴們的資源地址啄清。
加上了資源庫地址我們就已經(jīng)完成了,可以進行組件化的劃分了俺孙,具體是按照什么來劃分組件化的辣卒,可以查看最上面的那幾個鏈接,看看大牛們是如何闡述組件化的睛榄。