制作自己的Pod库(公有/私有)

2018-12-04 23:41:47

目的:1.管理自己常用的类;2.组件化开发

步骤:

1.想一个比较酷的名字,在桌面简历文件夹。

2.打开terminal,cd到这个文件夹下面,执行pod lib create  xxx(这里我们以JJCategoryKit为例子,下同)命令,如下图。这个过程会问几个问题,根据实际情况输入回答即可。这里我们选择添加demo,结束的时候会自动Lanuch这个app.

localhost:JJCategoryKit Jason$ pod lib create JJCategoryKit

3.将你需要制作的库文件,添加到Classes文件夹中,如下图所以。

4.修改JJCategoryKit.podspec索引。主要是修改s.homepage,s.source ,s.source_files,s.public_header_files。其中s.dependency为我们所依赖的第三库。其他诸如s.version ,s.summary等根据时间情况修改。

5.cd到Example下面运行pod install --no-repo-update 命令。这是点击workspce打开工程就可以看到我们添加的文件已经可以在工程里面了。

6. cd 到Example 上一层,(如果是在Example下可以cd ..)用pod lib lint 检测podspec是否正确。通常情况下是没有问题的,如果有错误根据提示修改就可以了,都是基本错误。

localhost:JJCategoryKit Jason$ pod lib lint

 ->JJCategoryKit (0.1.0)

    - ERROR | [iOS] file patterns: The `public_header_files` pattern did not match any file.

如这个错误就是s.public_header_files 要从'Pod/Classes/**/*.h' 改为'JJCategoryKit/Classes/**/*.h'。

看到这里也许有人发现第4步中的s.homepage,s.source 地址我们没有,这里说明。这个只需要我们在github或者oschina新建repositories 仓库即可。Repository name最好和你的库名称保持一致。 s.source就是对应的仓库地址,s.homepage对应主页,我们可以找一个好的页面或则直接就是你的GitHub主页也可以。

7.到这里本地的工作差不多已经做完了,接下来就是将我们的工程push到s.source对应的github仓库了。

依次执行:

localhost:JJCategoryKit Jason$ cd /Users/Jason/Desktop/JJCategoryKit/JJCategoryKit 

localhost:JJCategoryKit Jason$ git remote add origin https://github.com/anhuijhy/JJCategoryKit.git

localhost:JJCategoryKit Jason$ git add .

localhost:JJCategoryKit Jason$ git commit -a -m "0.1.0"

localhost:JJCategoryKit Jason$ git pull origin master

localhost:JJCategoryKit Jason$ git push origin master

localhost:JJCategoryKit Jason$ git tag 0.1.0

localhost:JJCategoryKit Jason$ git push origin 0.1.0

不出意外我们异步到github就可以看到我们的push了。而且包含了sepc中的相关信息,但是如果我们pod的话却发现没有找到我们pod库,那是因为公用的pod是要把spec上传到cocospod官方的。接着往下看........


8.将spec索引上传到官方需要先注册,命令如下

pod trunk register 电子邮箱 '您的姓名' --description='macbook pro'

注意邮箱必须正确,收到邮件后需要点击连接确认激活。

9.激活后江spec push到官方,这个过程可能需要一点时间,请耐心等等待。

localhost:JJCategoryKit Jason$ pod trunk push JJCategoryKit.podspec


等待之后就是✌️,如下图。

此时,在去github看的话,一些管pod的说明,也自动变好了。pod库终于可以使用了。



如果需要修改,执行下面的命令以提交更新..

git commit -m "1.0.0" (先提交当前修改)

git tag 1.0.1 (添加tag)

git push --tags (推送tag到远程)

git push origin master (推送到远程到代码仓库)

pod trunk push JJCategoryKit.podspec


10.如果pod 是私有,比如组件化开发,就不需要发布到官方,可以自己在github创建spec索引(也就是新建一个Repository),然后关联

a.pod repo可以查看本地索引库。

b.pod repo add <本地索引库的名字>  <远程索引库的地址> ,创建本地索引库并和远程索引库做关联(注:本地索引库的名字建议和远程索引库起的名字一样)。

c.cd 到本地索引库前面,pod spec lint - -verbose - -allow-warnings 检测索引库。

c.pod repo push <本地索引库> <索引文件名> - -verbose - -allow-warnings,提交到远程索引库。

d.pod需要使用的时候需要添加source '私有库地址' 到podfile文件。

11.错误解决:

a.如果trunk push 出现 error: include of non-modular header inside framework module ··· [-Werror,-Wnon-modular-include-in-framework-module] 可以 加上--use-libraries解决。

b.如果出现waring 可以加入 --allow-warnings



  • 2020-04-15 17:00:07

    export和import的理解,这一篇问扎根就够了

    在 ES6 之前,社区制定了一些模块加载方案,最主要的有 CommonJS 和 AMD 两种。前者用于服务器,后者用于浏览器。ES6 在语言标准的层面上,实现了模块功能,而且实现得相当简单,完全可以取代 CommonJS 和 AMD 规范,成为浏览器和服务器通用的模块解决方案。

  • 2020-04-15 21:14:13

    .d.ts与.ts的区别 .d.ts怎么用

    在TypeScript项目中直接引入Javascript包是不能使用的,因为包中缺少TypeScript类型声明,如果是自己写的包,可以考虑自己增加一个.d.ts类型声明文件,如果代码比较多或者使用的是第三方的包,自己写就比较麻烦了。第三方的包首先考虑找一个别人写好的声明文件,如果没有可以使用一些自动生成声明文件的工具。

  • 2020-04-17 09:27:38

    推荐一个老前端开发者的博客

    前端修炼场,首页标签大全greenSock前端研究VUE研究我们的作品flash技术探讨开发心得个人档案培训与招聘服务报价

  • 2020-04-17 09:41:47

    前端css博客推荐

    这个博客有大量的css内容,有svg,TweenMax等教程,抽空通读一下

  • 2020-04-17 10:20:47

    GreenSocks Animation Platform详细工作机制以及TweenMax用法

    GSAP(GreenSocks Animation Platform)是一个性能较好的前端动画库。最近在写一个前端SVG动画编辑器时选择了它作为底层的动画库。为了减少踩坑,我大致浏览了它的源代码,这篇文章主要是对我的理解进行记录。 我会先简单介绍一下这个动画库的API,再介绍它的插件机制,最后会从一个用例出发跟踪其运行机制。

  • 2020-04-17 10:39:02

    CSS 滤镜技巧与细节,实现火焰,融合等特效

    简单来说,CSS 滤镜就是提供类似 PS 的图形特效,像模糊,锐化或元素变色等功能。通常被用于调整图片,背景和边界的渲染。本文就会围绕这些滤镜展开,看看具体能怎么使用或者玩出什么花活。

  • 2020-04-17 10:42:29

    (三)TweenMax运动效果

    运动效果 实例化对象.set() 立刻运动到指定地点,不用加时间