前言
这篇文章和我的上一篇隔的时间是很长的,为什么呢?主要是因为我发现前面几篇文章虽然都是我们iOS开发过程中非常基础的知识,但是我实在是表达的很不好,可能是因为我刚开始写文章的原因吧。这段很长的时间,除了工作上的事情外,我花了很多时间去学习、阅读很多大V的博客、文章,受益良多,也更发现自己的文章是多么的不忍直视。也希望从这篇文章开始,成为一个分水岭,思路结构清晰的问章,方便他人,也方便自己。这段时间,其实无论是感悟还是接触的知识,都很多,但是很乱,写下来其实就是为了梳理梳理,也为以后积累下来,让自己又更快的进步,毕竟做iOS开发,已经2年多了,感觉自己成长实在太慢了,如今iOS的市场已经饱和,非常容易就会被淘汰,不管怎样,现在必须醒悟过来了。
本文写的是:
1.如何用一个工程开发几个类似的app
2.如何在工程中区别对待各个APP
3.自己的经验总结
需求
很多时候,当我们开发的一个大中型APP成熟以后,为适应业务的发展和市场的开拓,会有从APP中派生出不同的子APP,其功能可能也和本来的应用八九不离十,但是如果每个APP都是一个项目,后期维护成本将会成倍增长,不过幸运的是,我们已有一套方案可以省去绝大部分复制粘贴的时间,达到许多代码都能复用的效果。
解决方法
解决方案就是采用多个target这一可行有易于理解操作的方法,这个方案简单易懂,可能有缺点但是很实用。
首先复制出target(我随便拿了个demo作为例子):
修改复制出来的target的名字以区分,但是,scheme的编辑是必要的,只需要在Manage schemes中修改即可,如图:
接下来给demo2创建一个文件夹,并给新的target配备配置文件放入其中,首先是这三个:
通过右边的Target Membership 来指定这些配置的归属。然后修改bunle id 和这些配置文件的配置(比如APP的icon、luanchimage等等)即可。
这时,工程中就有两个target了,而一个target,会生成一个APP,我只需要用Target Membership勾选的方法,把两个APP共用的模块选中(当然,.h文件不需要如此):
其实这部分是比较繁琐的,可以把工程复制,然后采用拖拽copy的办法,只是记得勾选。但是这些共用的添加完了之后,两个APP差异的地方怎么体现呢?下面我讲讲我自己思考实践出来的处理办法,希望有更好办法的同学提出指正:
1.修改Build Settings --> Preprocessing --> Preprocessor Macro 此例子中我修改为DEMO1、DEMO2,用这个宏来区别两个target。
2.分别在原APP的文件夹和demo2文件夹中创建配置头文件,如demo1Config.h、demo2Config.h,这两个头文件中可以写两个APP都用的上但内容有差异的的宏(如根导航栏颜色等),也可以放入各自需要的类的头文件以区分。
3.在项目的公共配置文件(如.pch文件)中定义:
#ifdef DEMO1
#import "demo1Config.h"
#endif
//==========================================
#ifdef DEMO2
#import "demo2Config.h"
#endif
4.在有差异的地方用#ifdef XXX ..... #else ...... #endif 区别两个APP的差异代码,原理是当编译target demo2到#ifdef DEMO2 时,只会编译前面的代码 #else后面的代码会被跳过,这样就可以实现代码中的区分了。
这种方案需要注意头文件的import,如果你在target1的代码中使用了某个类但未导入它的头文件,在编译target2的时候是看不出来的,需要特别注意。
总结
在实际的开发中,这种方案确实能够省去我们很多时间,特别是当同时新增同样需求的时候,但是也相应带来了项目的pbxproj臃肿庞大,也让配置文件多了起来,如果差异处多的话,代码量、代码的工整性以及代码可读性都会有一定的影响,对于是不是用就需要见仁见智了,如果想思考替代方案的话,可以阅读参考另一种方案 ,本文结束。
网友评论