组件化
组件化其实就是将模块单独抽离、分层,并指定模块间的通讯方式,从而实现解耦的一种方式,通过组件化把代码分割在不同的格子里,把模块间的边界划分清楚,也方便未来优化或重构
组件化 是 App 膨胀到一定体积后的解决方案,能一定程度上解决问题,在提高开发效率的 过程中,采坑是难免的
组件化目标
- 模块间解耦
- 模块之间没有耦合,模块内部的修改不会影响其他模块
- 模块可以单独编译
- 模块间数据传递明确
- 模块可以随时被另一个提供了相同功能的模块替换
- 使用方便
- 模块对外接口清晰且易维护
- 当模块接口改变时,此模块的外部代码能够被高效重构
- 尽量用最少的修改和代码,让现有的项目实现模块化
- 支持OC和Swift,以及混编
组件化架构设计
将我们的项目大致分为3层:从上到下 业务层、通用层、基础层,只能上对下有依赖,不能下对上有依赖,横向依赖尽量稍有
组件化集成
使用cocoapods,毕竟用的人多
创建pods工程
终端执行 pod lib create XXXX
GitHub上有个模板,它把模板拉下来,创建一个工程
这个工程是根据模板创建的,东西很多,有的时候,我们只是创建一个很小的组件,其实只要3个文件+代码文件就够了
3个文件分别是LICENSE
、*.podspec
、README.md
将组件代码拷贝到主工程后
在主工程的Podfile
文件中添加导入代码
pod 'xx', :path => 'xx/xx' (组件代码路径)
组件配置podspec
部分选填字段说明
swift_versions 支持的Swift版本
s.swift_versions = ['5.0']
s.swift_versions = ['4.0', '5.0'']
s.swift_version = '5.0'
s.swift_version = '5.0', '4.0'
static_framework 包含静态库框架
s.static_framework = true
dependency 对其他Pod或“sub-spec”的依赖。依赖关系可以指定版本要求。
s.dependency 'AFNetworking', '~> 1.0'
s.dependency 'MTHawkeye','~> 0.12.1', :configurations => 'Debug'
s.dependency 'MTHawkeye','~> 0.12.1', :configurations => :debug
frameworks 当前target所需系统framework列表
s.frameworks = 'UIKit', 'MapKit'
exclude_files
从其他文件模式中排除的文件模式列表。
比如在设置某个子模块的时候,不需要包括其中的一些文件,就可以通过这个属性来进行设置。
non_arc_files = 'Sources/NSObjectSafe/*'
s.exclude_files = non_arc_files
requires_arc 指定使用ARC的source_files 默认是true
一般我们的需求是 arc使用非arc的代码
non_arc_files = 'Sources/NSObjectSafe/*'
s.exclude_files = non_arc_files
s.subspec 'no-arc' do |sp|
sp.source_files = non_arc_files
sp.requires_arc = false
libraries 当前target所需系统library列表
s.ios.library = 'xml2'
s.libraries = 'xml2', 'z'
pod_target_xcconfig 要添加到最终私有 pod目标xcconfig文件的任何标志。
ss.pod_target_xcconfig = { 'OTHER_LDFLAGS' => '-lObjC' }
public_header_files 用作公共头的文件模式列表。
s.public_header_files = 'Pod/Classes/**/*.h'
resource_bundles
为了将Pod构建为静态库,官方强烈建议使用此属性来管理资源文件,因为使用resources属性可能会发生名称冲突。
资源文件bundle的名称至少应包括Pod的名称,以最大程度地减少名称冲突的可能性。
s.resource_bundles = {
'Moduls' => ['Moduls/Assets/*.png']
}
resources
复制到target中的资源列表。
为了将Pod构建为静态库,官方建议是使用resource_bundle,因为使用resources属性可能会发生名称冲突。此外,使用此属性指定的资源将直接复制到客户端目标,因此Xcode不会对其进行优化。
spec.resource = 'Resources/xxxx.bundle'
spec.resources = ['Images/*.png', 'Sounds/*']
组件做好以后提交仓库
先验证podspec文件
pod spec lint
或者 pod lib lint
pod lib相当于只验证一个本地仓库
pod spec会同时验证本地仓库和远程仓库
再提交
pod repo push [本地Spec Repo名称][podspec文件路径]