组件化开发,cocoapods原理是什么?

说到组件化开发,网上可以看到很多资料,如蘑菇街滴滴淘宝携程豆瓣 、京东的组件化架构。但里面介绍比较多的是在现有app如何拆分,组件间如何通信。没有说组件该如何去搭建,像网络请求,json解析这些每个组件都需要用到的共用工具该如何处理。

找了好多资料,大部分都说使用cocoapods创建私有库,但是我的模块都是业务模块,也就是我的有些组件的共用性并不高啊!我只是想让每个业务线的代码解耦,方便装卸就可以。像支付宝这样,可以插件化的。

组件化开发,cocoapods原理是什么?

如果某个业务线停止了,我可以随时把代码从项目中拿掉。我还可以根据需求用现有的组件快速搭建出一个新的app。每个模块的逻辑都是相对独立,可能对应的服务都是不同团队提供,每个组件可以由不同的团队开发。cocoapods这个私有库虽然也可以实现,但是我觉的cocoapods大部分的用法都是在一些通用组件上,想我这样把一个大业务线规为一个组件的好像不是很合适。

cocoapods都做了些什么?pod进来的库是什么加载到主工程呢?

每个pod项目都会有一个.xcworkspace文件这个其实是苹果自带的功能,用来管理组合多个项目。还有一个Pods项目,这个项目里面就是放着一个个我们pod进来的第三方库和私有“组件”。这个Pods项目里面的代码和资源是什么引用到主项目里面的?

 

组件化开发,cocoapods原理是什么?

 

没错,一个个组件都被编译成静态库了,只要在主项目里面引用就可以。我们再找下到底是在哪里引用的?在主项目的Build Phases里面可以看到多了个Embed Pods Frameworks和Copy Pods Resources实行的就是2个.sh文件,这个2个脚本是干嘛的?ssell语言我不懂,但是我猜一个是合并静态库,一个是合并资源文件。为什么这么说,因为我看到主项目只引用了Pods.framework,那其它的库呢?合并到了Pods.framework里面了。

Pods只有一个工程什么可以编译出那么多个静态库?

我想这应该就是你在添加一个组件的时候脚本就会帮你添加一个TARGETS,看下项目:

组件化开发,cocoapods原理是什么?

果然是这样的。这些pods 插件都帮你做了,所以你都不需要自己去操作。如果不用pods的话这些就都需要你自己手动去做了,其实也是比较麻烦的事情,所以我觉的cocoapods和模块组件化可以搭配使用。我demo里面还不算完整,并没有把cocoapods加进去。网络上组件框架有些有提到cocoapods,有些并没用cocoapods,也许是项目组件化的比较早,cocoapods还不成熟还是别的原因,这个就不深究了。但是基本可以确定他们每个组件的格式都是静态库。早期我也是想每个组件是个独立的app,然后通过某种技术合并成一个app。但是最后找到的资料都是打成静态库(如果有别的方案希望可以分享下)

下面介绍下我的demo吧!

竟然要把我的业务模块打包成静态库,那每个模块用到一个通用的库该什么处理?如网络请求,json解析等,这些基本每个模块都是需要的,难道都要重复编译到每个组件里面?不不不,且不说会不会冲突,就是安装包也该大了不少吧?那如何共用这些通用组件呢?还有我既然是同一个app那我的界面风格应该也是差不多的,所以可能每个模块都需要继承同一个基类。所以我的做法就是把这些每个组建都必须用的都抽出来打成一个通用的组件,给每个业务组件依赖。至于资源文件的处理我觉的可以参考cocoapods的原理。

就写到这里吧!更多的坑等着我们去踩!一起加油