美文网首页
组件化开发之创建CocoaPod

组件化开发之创建CocoaPod

作者: 红茶绅士 | 来源:发表于2017-07-17 18:53 被阅读24次

组件化的架构设计,是将每个模块作为一个组件.每个组件都当做一个独立工程,并建立主项目来集成所有组件.集成方式是在主项目中通过CocoaPods来集成,将所有组件当做第三方库集成到项目中.

创建Pod库文件

  • 使用命令创建本地Pod库
    输入 -pod lib create XMLYMain- 命令后,会询问语言类型\是否创建Demo等信息,依次输入最终会创建一个如下图所示的文件目录.
What language do you want to use?? [ Swift / ObjC ]
 > ObjC
Would you like to include a demo application with your library? [ Yes / No ]
 > Yes
Which testing frameworks will you use? [ Specta / Kiwi / None ]
 > None
Would you like to do view based testing? [ Yes / No ]
 > No
What is your class prefix?
 > XMLY          
文件目录结构.png

创建过程中没有提示我输入author等信息,应该是我之前已经在MBP上配置过github账号的原因

文件作用

  • license 文件
    CocoaPods 强制要求所有的 Pod 依赖库都必须有 license 文件,否则验证不会通过.这里一般是MIT类型的license.

  • Example
    刚才创建的时候Would you like to include a demo application with your library?选择了Yes.这个文件就是命令帮我们创建的Demo工程文件.用来向其他使用者展示该Pod的使用.

  • XMLYMain
    与创建的Pod库同名,里面有两个文件夹AssetsClasses

    • Assets - 存放Pod库中所需的资源文件(如.png .plist)
    • Classes - 存放Pod库的实例类
  • XMLYMain.podspec
    .podspec 是Pod库的配置文件,其中属性已经自动生成.我们需要注意的是s.version,以后每次对Pod库的修改都需要修改version,并创建提交修改的tag.

Pod::Spec.new do |s|
  s.name             = 'XMLYMain'
  s.version          = '0.1.0'
  s.summary          = 'XMLYMain'

  s.description      = <<-DESC
'XMLYMain':项目的主要框架
                       DESC

  s.homepage         = 'https://github.com/caiiiac/XMLYMain'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { 'caiiiac' => 'caiiiac@163.com' }
  s.source           = { :git => 'https://github.com/caiiiac/XMLYMain.git', :tag => s.version.to_s }
  # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'

  s.ios.deployment_target = '8.0'

  s.source_files = 'XMLYMain/Classes/**/*'

  # s.resource_bundles = {
  #   'XMLYMain' => ['XMLYMain/Assets/*.png']
  # }

  # s.public_header_files = 'Pod/Classes/**/*.h'
  # s.frameworks = 'UIKit', 'MapKit'
  # s.dependency 'AFNetworking', '~> 2.3'
end
  • 验证的时候可能会遇到的问题 - WARN | summary: The summary is not meaningful.
    请参照上面修改.podspec文件里的s.summarys.description字段

提交Pod到github

  • 关联github
    首先在github上创建同名项目,cd命令进入本地XMLYMain目录
cd XMLYMain
git remote add origin https://github.com/caiiiac/XMLYMain.git
git push -u origin master
WX20170717-164105@2x.png
  • 添加文件并设tag
    将自己开发的.h .m文件保存到XMLYMain -> Classes目录中
    将需要的资源文件保存到XMLYMain -> Assets目录中
git add .
git commit -m "0.1.0 init"
git push origin master
git tag '0.1.0'
git push --tags
  • 验证Pod
    pod lib lint
    如果一切正常就会输出
-> XMLYMain (0.1.0)
XMLYMain passed validation.

部署Pod

这里我们将会使用到Trunk,CocoaPods 使用 trunk 服务让我们来提交 Pod.

  • 注册Trunk
    pod trunk register caiiiac@163.com 'caiiiac' --description='trunk with MacBook Pro' --verbose
    注意将邮箱 - 名字 - 描述文字改成自己的

稍候CocoaPods 会给你的邮箱发送验证链接,验证成功后,可以用 pod trunk me 命令查看自己的注册信息

  • 部署Pod
    通过pod trunk push XMLYMain.podspec命令部署你的Pod
    注意将podspec的文件换成你自己的文件名,成功后会出现提示信息
 🎉  Congrats

 🚀  XMLYMain (0.1.0) successfully published
 📅  July 17th, 03:53
 🌎  https://cocoapods.org/pods/XMLYMain
 👍  Tell your friends!

搜索你的Pod

  • 运行 pod reop update 来更新本地索引库
  • 使用 pod search XMLYMain 命令来查找你刚刚部署成功的Pod

如果还是搜索不到,提示Unable to find a pod with name, author, summary, or description matching XMLYMain

  • 解决方法: 前往缓存目录/Users/你的目录名/Library/Caches/CocoaPods 删除search_index.json文件,当你再次pod search的时候会重新生成.

相关文章

网友评论

      本文标题:组件化开发之创建CocoaPod

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