iOS组件化开发实施一期文档

组件化

组件化开发系列:
(一)iOS组件化开发架构设计思考
(二)iOS组件化开发实施一期文档

前言

   我们在谈模块化、组件化,中心路由,响应式编程,三层、四层架构,依赖注入等概念的时候,出发点是什么?应该是项目管理上的稳定性,可维护性,开发效率,需要从业务中提炼出更抽象的结构思想,不要为了架构而架构,流于形式。软件项目开发的整个周期内都应该考虑这些问题,而且是持续性的,关键是我们一定要有设计思想、负责的态度、认真的执行力。具体有必要做哪些,可以根据实际情况,做好预案,逐步实施。

   其实好多事情,我们也可以借势去推动,帮助公司和个人成长。项目的重构,资源的重组,也是资源和权利的再分配。

一、目标

梳理项目工程结构,抽离基础层和中间层

  1. 保证所有第三方库管理、基础库从主工程抽出,可独立编译,减少编译时间。

  2. 梳理提供的功能和使用方法,便于各业务模块的调用。

  3. 让团队成员更熟悉公司项目,减少重复造轮子,提高开发效率。

二、实施计划

1、实施说明

  1. 专门建立一个组件化的分支组,组件化的主分支和多个改动分支。组件化的主分支,以周为单位,进行review和合并代码使用,并标记tag和提交测试,以便改动可以随版本发布,建议专人负责管控。
  2. 每次都小步改动和改动单一性(如调整文件路径、修改工程名称、改动了Pods等单独进行),并及时编译,验证改动是否正确,成功后提交。
  3. 尽量在不改动代码逻辑的情况下做调整。较大的改动,如修改了逻辑、移动了某个库到其他工程、改动了Pods、删除了某些文件,可以做些记录或提交代码时做详细的说明,以便问题复查。
  4. 移动文件时,注意文件环境MRC/ARC的变化,如需要请尽量改动为ARC。

2、项目工程定义

初步调整工程目录结构如下:

基础层和中间层

Pods: 仅Pods管理的第三方库。
DDManualThirdSDKs: Pods不能管理的第三方库,对第三方进行必要的封装,集中做成私有库的形式,再交给Pods管理。
DDDevelopLib: 自行封装的私有库,如系统类分类、数据处理类、通用UI组件、宏定义和常量定义等。做成私有库,交给Pods管理。

业务组件层

DDEngine: 后续会把模型规整到具体模块中,部分文件需要抽离到基础层或中间层,其他暂时保持不变,后续抽离封装网络库。
DDMIX_UI: 暂时保留,属于三期。
ddDemo: 将其中的第三方库、UILib、分类等,下沉到基础层或中间层外,暂时保持不变。

基础层中间层工程通用的目录结构

以DDManualThirdSDKs为例说明,目录结构如下:

DDManualThirdSDKs:工程代码

CoreCode:核心代码
Resources:需要的资源文件。
SupportingFiles:.pch, .plist等。

Frameworks:依赖的系统库。
Products:编译好的.a文件。
Pods:pods配置文件。

一二级目录是标准配置,三、四、五根据需要自行配置。

调整要点

  1. 每个工程下都需要建立一个README.md 文件,写明工程使用说明,后续交由指定人员,轮流负责管理。
  2. 每个工程除了依赖更底层库外,都能独立编译,并无警告⚠️,第三库可以采用忽略的形式隐藏,自行编写的代码必须无警告。
  3. 文件路径使用真实路径,项目目录和真实路径一致,除了工程级的Frameworks、Products、Pods除外,禁止使用虚拟路径。

参考扩展文档
1、iOS Workspace 多项目管理
2、iOS多个Target配置详情操作
3、iOS工程目录结构的思考
4、CocoaPods进阶:详解私有库制作
5、iOS工程文件整理

3、整理三方库统一Pods管理

把项目中散落的第三方库都规整到Pods和DDManualThirdSDKs工程中,优先Pods管理。
散落的第三方库有:iflyMSC、libSunFlower、DDReader、YYText、MiaoZhen、NTalkerUIKitSDK、TalkingData、VoiceConvert、HPGrowingTextView(7年未维护了,局部使用,可以内化为自行代码)等。

DDManualThirdSDKs工程 CoreCode文件夹下目录结构:

CoreCode:核心代码

YiGuanFangZhou:YiGuanFangZhou 代码区。

PackageLayer:YiGuanFangZhou 封装(根据需要封装)。
SDKCode:YiGuanFangZhou SDK代码。

QQSDK:QQSDK代码。

PackageLayer:QQSDK 封装(根据需要封装)。
SDKCode:QQSDK代码。

把pod管理第三方库有自行封装的代码集中到一个文件下参考目录结构:

DDPodSDKsPackage:工程代码

AFNetworkingPackage:AFNetworking 封装代码(根据需要封装)。
SDWebImagePackage:SDWebImage 封装代码。
WechatSDKPackage:DDWeChatPay、WeixinService等

调整要点

  1. DDManualThirdSDKs工程下,创建DDManualThirdSDKsREADME.md,做好第三方库记录和说明,再将DDManualThirdSDKs打包成一个私有库,用Pods管理。

  2. 移除不使用的旧库,有重大功能变更的库,给出升级或替换或保持现状的建议。

  3. 把所有使用的三方库,梳理进一个在线表格。三方库的使用版本、最高版本、主要功能、哪些模块使用(全部、多个模块、单独模块)、依赖库、备注项,后续有指定人员维护。

4、梳理DDDevelopLib私有库

自行封装的私有库,作为整个工程的基础库,不与具体的业务耦合,如系统类分类、数据处理类、通用UI组件、宏定义和常量定义等。做成私有库,交给Pods管理。如ddDemo中的VerifyUpdate、UILib、DDAppkit、Common、Categorys、Function、DDMonkey等。

CoreCode文件夹主要文件分类如下:

CoreCode:核心代码

DDCategorys:系统分类。
DDData:通用的数据。
DDUILib:通用的UI库,如评分星星,轮播图,大图查看器等。
DDConfigs:宏定义和常量定义项目,如字体适配,颜色值等。
DDFunctionLib:绝对单纯的数据处理工具类,静态方法,非空判断、日期字符串和日期对象的转换等。

调整要点

  1. 新增DDDevelopLibREADME.md,管理库能提供的功能,使用说明,修改说明,后续有指定人员维护。

  2. 主要移动文件夹,尽量少的改动逻辑,若项目中有存在相同逻辑或需要抽取代码时,请做好修改记录和review代码。

5、Resources文件整理

初步整理Resources资源文件,后期会根据资源情况再统一整理图片资源,注意资源文件的加载路径的变化后,保证资源文件能正常加载。

参考目录结构如下:

Images.xcassets:图片系统管理器
DDFonts:字体库
gif:动图管理
Data:数据资源文件

plist:plist文件
json:json文件

调整要点

  1. 将Other Sources虚拟文件夹中的plist整理到Resources中。
  2. 将项目中使用的图片、Plist文件、音视频文件,暂时归整到Resources文件下。

6、SupportingFiles文件整理

创建真实目录SupportingFiles,文件路径有所变化,请在项目配置中调整,存放系统支持文件如下:

main.m
ddDemo-Info.plist
ddDemo_Prefix.pch
DDDebug.entitlements

三、工期评估

参照实施文档进行,初步评估工期为14天,后续遇到问题,及时沟通调整。


参考工期

四、其他细节

  1. 开发人员的协调问题。
  2. 代码review管控。
  3. 提测,上线进度把控。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容