0
点赞
收藏
分享

微信扫一扫

iOS 组件化

Python百事通 2021-09-19 阅读 72
随笔

组件化

组件化其实就是将模块单独抽离、分层,并指定模块间的通讯方式,从而实现解耦的一种方式,通过组件化把代码分割在不同的格子里,把模块间的边界划分清楚,也方便未来优化或重构

组件化 是 App 膨胀到一定体积后的解决方案,能一定程度上解决问题,在提高开发效率的 过程中,采坑是难免的

组件化目标

  1. 模块间解耦
    • 模块之间没有耦合,模块内部的修改不会影响其他模块
    • 模块可以单独编译
    • 模块间数据传递明确
    • 模块可以随时被另一个提供了相同功能的模块替换
  2. 使用方便
    • 模块对外接口清晰且易维护
    • 当模块接口改变时,此模块的外部代码能够被高效重构
    • 尽量用最少的修改和代码,让现有的项目实现模块化
    • 支持OC和Swift,以及混编

组件化架构设计

将我们的项目大致分为3层:从上到下 业务层、通用层、基础层,只能上对下有依赖,不能下对上有依赖,横向依赖尽量稍有


组件化集成

使用cocoapods,毕竟用的人多

创建pods工程
终端执行 pod lib create XXXX
GitHub上有个模板,它把模板拉下来,创建一个工程

这个工程是根据模板创建的,东西很多,有的时候,我们只是创建一个很小的组件,其实只要3个文件+代码文件就够了
3个文件分别是LICENSE*.podspecREADME.md

将组件代码拷贝到主工程后

在主工程的Podfile文件中添加导入代码

pod 'xx', :path => 'xx/xx' (组件代码路径)

组件配置podspec

官方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文件路径]

举报

相关推荐

0 条评论