最近在重构公司的多个APP项目,其中有好多个APP基本一致,都是由一个公版APP派生出来。这些APP中,有些只是更换了icon和启动页,以及证书及发布账号,最特殊的也就是在公版APP上添加或删除了部分功能和界面等;但是,当我看到源代码的时候,我的内心是崩溃的,当时就瘫倒在地。。。

居然所有的项目都有一个单独的工程,而且由于公版APP并不是很稳定,导致其他派生的APP问题不断,这就有一个致命的问题,就是每次在公版APP上改完问题,还要重新再派生APP上更改;有些很久不更新的派生APP,代码年代更是追溯到公园前。
摊上这样的摊子,内心虽然崩溃,但是觉得刚好可以锻炼下自己这方面的水平,毕竟以前也没有机会接触这样的情况;废话不多说,直接进入正题,说明我是如何解决这种问题的;
我的解决方案是:使用Target创建大量相似的APP;
其实,通过创建Target并不只适用于生产大量相似APP,还可以用在区分不同的编译环境,比如,可以针对开发、发布、以及测试创建不同的Target,便于管理一份工程代码;因此,当多个工程有大部分内容完全一样的话,就可以考虑使用Terget来更好的管理工程代码;
这样的好处主要有以下几点:
- 只需管理一份代码,避免了在多个工程间来回切换更改代码,产生遗漏;
- 加快派生APP的生产并优化管理;
- 优化各环境版本的控制;
应该还有其他用处,暂时只想到这些;
具体实施细节如下:
-
首先,右键点击公版APP 的target,Duplicate(复制)当前Target,这样操作会生成新的Target、新的plist文件,以及其对应的scheme;
复制Target.png
-
生成新的Target,左键点击可重新命名;
产生新Target.png
-
更改plist文件为更加具体的名称(如果使用默认名称,3、4步骤可省略);
更改plist文件名称.png
-
由于改了plist文件名字,因此需要重新选择当前Target的plist文件位置,在更改完位置后,可以针对对应APP的Display Name、BundleID及版本号等进行具体的设置;
重新选择plist文件位置.png
-
点击当前APP,选择manage schemes,然后更改相应target的名称;
管理Scheme.png
更改Scheme名称.png
-
如果针对每个target有不同的icon,可以在images中添加(如果不涉及更换icon或Launch Screen,则6、7可省略);
添加派生APP的icon.png
-
选择对应target的icon及Launch Screen
选择对应target的icon及Launch Screen.png
-
最后也是最重要的一步,就是要在build setting中的Macro中添加相应的宏定义,然后在pch或者类代码中通过#if #elif #endif等语句实现不同target的不同逻辑;
通过添加宏管理工程代码.png
在pch中通过宏编译语句实现不同target的功能.png
-
还有一点需要注意的就是在添加文件或者指定相应文件所属Target可以通过以下方式实现
新增文件指定target.png
指定相应文件所属target.png
-
如果嫌以上指定文件方法太麻烦,可以直接在每个target的build Phases中管理;
target文件管理源.png
暂时先写这些,以后想起其他内容在维护,如有更好的建议或意见请联系;
网友评论