一、二进制化
具体如何实现二进制化可以查看 二进制化(一)静态库 或者二进制化(二)Framework
二、组件二进制化
在前面几篇中说明了如何制作组件,本篇将说明如何把组件进行二进制,本篇组件二进制化使用的是Framework
1、在组件工程中创建一个Framework工程 创建复合工程.png
2、配置Framework支持的最低版本,这将会影响到编译出来的Framework包含哪些架构,如果选择的最低版本是8.0,在模拟器情况下,编译出来的Framework包含i386、x86_64架构;如果选择的最低版本是11.0,同样在模拟器情况下,编译出来的Framework只有x86_64架构 配置Framework支持的最低版本.png
3、配置Framework支持的架构,当设置为YES的时候,在模拟器环境下,编译后的Framework只包含x86_64架构;当设置为NO的时候,同样在模拟器环境下,编译后的Framework包含i386、x86_64架构 配置支持架构.png
4、配置Framework为静态库,在创建的Framework默认情况下是动态库,关于具体的Framework详情可以查看二进制化(二)Framework 配置Framework为静态库.png
5、配置生成的Framework为release环境 配置Framework为release环境.png
6、把源码拖动到Framework库中,最好在拖动代码的时候选择引用当前代码而不是重新拷贝一份代码,这样便于代码维护 拖动源码.png
7、把组件中的.h文件暴露出去,其实在创建Framework时,就自动暴露了一个Framework.h文件,我们可以把组件中的.h文件写入到这个Framework.h中,但是如果组件已在项目中使用,现在以二进制的方式载入工程时,必将会报错。所以我们可以把组件中的.h文件自动选择暴露出去 暴露头文件.png
8、修改编译生成的Framework所在路径,因为默认的路径不是很好找 修改编译生成的Framework的路径.png 修改编译生成的Framework路径2.png 修改编译生成Framework的路径3.png
9、编辑podspec文件
#.h文件路径
s.source_files = 'RevanFunctionModule/Classes/**/*.h'
#Framework路径
s.vendored_frameworks = 'RevanFunctionModule/Products/Release-iphonesimulator/*'
#引用静态库路径
s.vendored_libraries = '.a文件路径'
10、pod install后组件以二进制的形式载入工程中,到目前为止组件二进制化以及完成
pod install后组件以二进制载入工程.png三、优化问题
1、Subspecs一起打包成一个Framework,现在只要引入组件中的一种功能,都会把整个组件引入,这样会造成包的增大
- Subspecs:
- RevanFunctionModule/RevanSeg (0.4.12)
- RevanFunctionModule/RevanDown (0.4.12)
- RevanFunctionModule/RevanPer (0.4.12)
- RevanFunctionModule/RevanD (0.4.12)
- 1、可以把每一个子功能组件创建成一个Framework 每一个子功能模块做成一个Framework库.png
2、当我们以现在的形式把组件引入工程中时,组件是以二进制形式呈现的,这样有一个弊端就是如果组件中有bug时,无法定位bug。可以通过增添环境配置来决定导入的是Framework还是源码
#如果在执行pod install 或pod update之前添加 IS_SOURCE=1时加载源码,否则二进制
if ENV['IS_SOURCE']
s.subspec 'RevanSeg' do |seg|
seg.source_files = 'RevanFunctionModule/Classes/RevanSeg/**/*'
end
else
s.subspec 'RevanSeg' do |seg|
seg.source_files = 'RevanFunctionModule/Classes/RevanSeg/**/*.h'
seg.vendored_frameworks = 'RevanFunctionModule/Products/Release-iphonesimulator/RevanSegmentFramework.framework'
end
end
3、组件依赖三方框架
- 在组件的二进制化的时候,有些组件会依赖三方框架,但是不能把三方框架的源码加载到Framework中,出现这样的问题一般都是使用了自动打包工具
- 此时把有依赖第三方框架的组件导入Framework中时,编译时不会通过的,可以通过在Podfile中给Framework target添加依赖
use_frameworks!
target 'RevanBase_Example' do
pod 'RevanBase', :path => '../'
target 'RevanBase_Tests' do
inherit! :search_paths
end
#给Framework添加依赖
target 'RevanBaseFramework' do
end
end
- 此时这个二进制组件的spec
s.source_files = 'RevanBase/Classes/**/*.h'
s.vendored_frameworks = "RevanBase/Products/RevanBaseFramework.framework"
s.dependency 'AFNetworking'
网友评论