iOS項(xiàng)目目錄結(jié)構(gòu)和開發(fā)流程
網(wǎng)上關(guān)于iOS項(xiàng)目的資源不多,開源的且質(zhì)量還不錯的iOS項(xiàng)目也是少之又少,最近正好跟同事合作了一個iOS項(xiàng)目,來說說自己的一些想法。
目錄結(jié)構(gòu)
AppDelegate Models Macro General Helpers Vendors Sections Resources
一個合理的目錄結(jié)構(gòu)首先應(yīng)該是清晰的,讓人一眼看上去就能大概了解目錄的職責(zé),且容易應(yīng)對新的變化。
AppDelegate
這個目錄下放的是AppDelegate.h(.m)文件,是整個應(yīng)用的入口文件,所以單獨(dú)拿出來。
Models
這個目錄下放一些與數(shù)據(jù)相關(guān)的Model文件,里面大概是這樣:
Models |- BaseModel.h |- BaseModel.m |- CollectionModel.h |- CollectionModel.m ...
Macro
這個目錄下放了整個應(yīng)用會用到的宏定義,里面大概是這樣:
Macro |- AppMacro.h |- NotificationMacro.h |- VendorMacro.h |- UtilsMacro.h ...
AppMacro.h 里放app相關(guān)的宏定義,如:
// 表情相關(guān)
- #define EMOTION_CACHE_PATH @"cachedemotions"
- #define EMOTION_RECENT_USED @"recentusedemotions"
- #define EMOTION_CATEGORIES @"categoryemotions"
- #define EMOTION_TOPICS @"emotiontopics"
// 收藏相關(guān)
#define COLLECT_CACHE_PATH @"collected"
// 配圖相關(guān)
#define WATERFALL_ITEM_HEIGHT_MAX 300 #define WATERFALL_ITEM_WIDTH 146
NotificationMacro.h 里放的是通知相關(guān)的宏定義。
UtilsMacro.h 里放的是一些方便使用的宏定義,如:
- #define UIColorFromRGB(r,g,b) [UIColor \
- colorWithRed:r/255.0 \
- green:g/255.0 \
- blue:b/255.0 alpha:1]
- #define NSStringFromInt(intValue) [NSString stringWithFormat:@"%d",intValue]
VendorMacro.h 里放一些第三方常量,如:
- #define UMENG_KEY @"xxxxx"
- #define UMENG_CHANNEL_ID @"xxx"
如果有新的類型的宏定義,可以再新建一個相關(guān)的Macro.h。
General
這個目錄放會被重用的Views/Classes和Categories。里面大概是這樣:
General |- Views |- TPKScollView |- TPKPullToRefresh ... |- Classes |- TPKBaseViewController |- TPKHorizontalView ... | - Categories |- UIViewController+Sizzle |- UIImageView+Downloader ...
這里的TPK是項(xiàng)目的首字母縮寫。
Helpers
這個目錄放一些助手類,文件名與功能掛鉤。里面大概是這樣:
Helpers |- TPKShareHelper |- TPDBHelper |- TPKEmotionHelper ...
助手類的主要作用是幫助Controller瘦身,也可以提供一定程度的復(fù)用。
Vendors
這個目錄放第三方的類庫/SDK,如UMeng、WeiboSDK、WeixinSDK等等。
Sections
這個目錄下面的文件對應(yīng)的是app的具體單元,如導(dǎo)航、瀑布流等等。里面大概是這樣:
Sections |- Menu |- Setting |- Collection ...
Resources
這個目錄下放的是app會用到的一些資源,主要是圖片。
Cocoapods
業(yè)務(wù)無關(guān)的類庫可以通過 Cocoapods 來方便地管理,如SDWebImage, Reachability等等。還有一些是多個應(yīng)用都會用到的基礎(chǔ)模塊,比如HBAPI、HBSNS 、HBFoundation(HB為公司名首字母)等等,可以建一個私有的git repo,然后加到podfile中,這樣如果HBAPI有更新,只需要pod update一下就行了。
順便說一下HBFoundation,這個git倉庫中可以放一些自己寫的所有應(yīng)用基本上都會用到的小模塊。如很多app都會有隔一段時間跳出 一個求好評的alertView,就可以寫一個HBRating類,這樣需要使用該功能的app只需加上一句:[HBRating checkIfShouldPopupWithAppID:(NSInteger)appID]就行了。又比如app都有接受push notification的需求,可以寫一個HBAPNS類,等等。
開發(fā)流程
在拿到設(shè)計(jì)圖后,就可以針對設(shè)計(jì)圖抽離出可復(fù)用的Classes/Views/Helpers,考慮一下某個效果的具體實(shí)現(xiàn),使用合適的設(shè)計(jì)模 式來避免大量的if/else嵌套,等等。不要一下子就鉆到Sections中去實(shí)現(xiàn)頁面效果和功能,初看起來可能會快一點(diǎn),但只要有點(diǎn)復(fù)雜度的項(xiàng)目,這 種做法到后來只會吃盡苦頭,代碼會變的越來越難維護(hù)。所以前期一定要做好充足的準(zhǔn)備工作。