iOS項(xiàng)目的目錄結(jié)構(gòu)和開(kāi)發(fā)流程
網(wǎng)上相關(guān)的資源不多,開(kāi)源的且質(zhì)量還不錯(cuò)的iOS項(xiàng)目也是少之又少,最近正好跟同事合作了一個(gè)iOS項(xiàng)目,來(lái)說(shuō)說(shuō)自己的一些想法。
目錄結(jié)構(gòu)
- AppDelegate
- Models
- Macro
- General
- Helpers
- Vendors
- Sections
- Resources
一個(gè)合理的目錄結(jié)構(gòu)首先應(yīng)該是清晰的,讓人一眼看上去就能大概了解目錄的職責(zé),且容易應(yīng)對(duì)新的變化。
AppDelegate
這個(gè)目錄下放的是AppDelegate.h(.m)文件,是整個(gè)應(yīng)用的入口文件,所以單獨(dú)拿出來(lái)。
Models
這個(gè)目錄下放一些與數(shù)據(jù)相關(guān)的Model文件,里面大概是這樣:
- Models
- |- BaseModel.h
- |- BaseModel.m
- |- CollectionModel.h
- |- CollectionModel.m
- ...
Macro
這個(gè)目錄下放了整個(gè)應(yīng)用會(huì)用到的宏定義,里面大概是這樣:
- 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"
如果有新的類(lèi)型的宏定義,可以再新建一個(gè)相關(guān)的Macro.h。
General
這個(gè)目錄放會(huì)被重用的Views/Classes和Categories。里面大概是這樣:
- General
- |- Views
- |- TPKScollView
- |- TPKPullToRefresh
- ...
- |- Classes
- |- TPKBaseViewController
- |- TPKHorizontalView
- ...
- | - Categories
- |- UIViewController+Sizzle
- |- UIImageView+Downloader
- ...
這里的TPK
是項(xiàng)目的首字母縮寫(xiě)。
Helpers
這個(gè)目錄放一些助手類(lèi),文件名與功能掛鉤。里面大概是這樣:
- Helpers
- |- TPKShareHelper
- |- TPDBHelper
- |- TPKEmotionHelper
- ...
助手類(lèi)的主要作用是幫助Controller瘦身,也可以提供一定程度的復(fù)用。
Vendors
這個(gè)目錄放第三方的類(lèi)庫(kù)/SDK,如UMeng、WeiboSDK、WeixinSDK等等。
Sections
這個(gè)目錄下面的文件對(duì)應(yīng)的是app的具體單元,如導(dǎo)航、瀑布流等等。里面大概是這樣:
- Sections
- |- Menu
- |- Setting
- |- Collection
- ...
Resources
這個(gè)目錄下放的是app會(huì)用到的一些資源,主要是圖片。
Cocoapods
業(yè)務(wù)無(wú)關(guān)的類(lèi)庫(kù)可以通過(guò) Cocoapods 來(lái)方便地管理,如SDWebImage
, Reachability
等等。還有一些是多個(gè)應(yīng)用都會(huì)用到的基礎(chǔ)模塊,比如HBAPI、HBSNS 、HBFoundation(HB為公司名首字母)等等,可以建一個(gè)私有的git repo,然后加到podfile中,這樣如果HBAPI有更新,只需要pod update
一下就行了。
順便說(shuō)一下HBFoundation
,這個(gè)git倉(cāng)庫(kù)中可以放一些自己寫(xiě)的所有應(yīng)用基本上都會(huì)用到的小模塊。如很多app都會(huì)有隔一段時(shí)間跳出一個(gè)求好評(píng)的alertView,就可以寫(xiě)一個(gè)HBRating
類(lèi),這樣需要使用該功能的app只需加上一句:[HBRating checkIfShouldPopupWithAppID:(NSInteger)appID]
就行了。又比如app都有接受push notification的需求,可以寫(xiě)一個(gè)HBAPNS
類(lèi),等等。
開(kāi)發(fā)流程
在拿到設(shè)計(jì)圖后,就可以針對(duì)設(shè)計(jì)圖抽離出可復(fù)用的Classes/Views/Helpers,考慮一下某個(gè)效果的具體實(shí)現(xiàn),使用合適的設(shè)計(jì)模式來(lái) 避免大量的if/else嵌套,等等。不要一下子就鉆到Sections中去實(shí)現(xiàn)頁(yè)面效果和功能,初看起來(lái)可能會(huì)快一點(diǎn),但只要有點(diǎn)復(fù)雜度的項(xiàng)目,這種做 法到后來(lái)只會(huì)吃盡苦頭,代碼會(huì)變的越來(lái)越難維護(hù)。所以前期一定要做好充足的準(zhǔn)備工作。
經(jīng)驗(yàn)有限,如果你有更好的想法,歡迎交流:)
【移動(dòng)開(kāi)發(fā)視頻課程推薦】
- iOS培訓(xùn)之Objective-C基礎(chǔ)視頻教程(40集)
- Cocos2d-x從零開(kāi)始【5天掌握跨平臺(tái)游戲開(kāi)發(fā)利器】(12集)
- Objective C編程基礎(chǔ)(24集)
- Android技術(shù)輕松入門(mén)課程(12集)
- 微信開(kāi)放平臺(tái)-Android應(yīng)用接入(4集)
- Cocos2d-x跨平臺(tái)游戲開(kāi)發(fā)入門(mén)基礎(chǔ)(29集)
- iOS開(kāi)發(fā)視頻教程-iOS網(wǎng)絡(luò)編程【高級(jí)篇】(39集)
- 移動(dòng)應(yīng)用用戶(hù)體驗(yàn)設(shè)計(jì)高級(jí)課程(60集)
- 從零學(xué)習(xí)iOS開(kāi)發(fā)–UI多視圖(30集)
- iOS開(kāi)發(fā)視頻教程【基礎(chǔ)入門(mén)篇】