美文网首页
iOS 组件化

iOS 组件化

作者: H丶ym | 来源:发表于2021-03-30 16:37 被阅读0次

    组件化

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

    组件化 是 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文件路径]

    相关文章

      网友评论

          本文标题:iOS 组件化

          本文链接:https://www.haomeiwen.com/subject/cgtghltx.html