react-native项目中接入MJRefresh,link完,debug没问题,打包报错:
clang: error: no such file or directory: ‘***/Intermediates.noindex/ArchiveIntermediates/KnowBall/BuildProductsPath/Release-iphoneos/libRCTMJRefreshHeader.a’
解决办法:
第一步:libRCTMJRefreshHeader.a加到Link Binary With Libraries中
第二步:修改RCTMJRefreshHeader项目,iOS Deployment Target 改成跟你项目一致版本
第三步:找到你项目配置Build Settings —>Header Search Paths,把$(SRCROOT)/../node_modules/react-native-mjrefresh/ios/RCTMJRefreshHeader/RCTMJRefreshHeader删掉。
clean一下,重新打包。
如果不行,打开/Users/sj/Library/Developer/Xcode/DerivedData ,把里面的当前项目缓存删掉,再试一下。
心里路程:(分析问题原因,不想看的小伙伴可以close了)
1、网上给的解决方法: 没用!!
链接:https://github.com/react-native-studio/react-native-MJRefresh/issues/11
将 RCTMJRefreshHeader lib 加入 Build Phases -> Target Dependencies 中,并将Build Phases -> Link Binary With Libraries中的libRCTMJRefreshHeader.a删掉。
archive成功了!以为到这里就好了,分析原因,为什么加到这里就好了?
Target Dependencies 顾名思义项目依赖,是用来指定编译顺序的。
工程在编译Target之前要先编译好Target Dependencies中的库,
那我们可以理解为libRCTMJRefreshHeader.a没有找到,然后编译的时候生成的,如果这样那么生成一次后再改回来是不是也能运行成功?答案是不可以。
显然不是因为没编译问题。
然后我把上面的设置还原,也就是把libRCTMJRefreshHeader.a从Target Dependencies中去掉,还加到Link Binary With Libraries,同时把Build Active Architecture Only的release也设置YES,竟然也能运行成功了。
Build Active Architecture Only又是什么玩意呢?它是控制你编译工程的时候所有架构(armv7、armv7s、armv64)都编译还是只编译当前设备的,YES只编译当前,NO是所有。debug模式为了速度,只编译当前;release就得编译所有了,否则发出去别的机型不能用还怎么玩?
我们接着看,我思考了一下,debug能运行,release不可以,一定是哪里配置不一样,我看了下工程配置,发现
Build Active Architecture Only这个选项debug:YES release:NO
再看下原来的错误详细信息,有这样一段:
Showing Recent Messages
Ld ***/ArchiveIntermediates/KnowBall/IntermediateBuildFilesPath/KnowBall.build/Release-iphoneos/KnowBall.build/Objects-normal/armv7/KnowBall normal armv7 (in target: **)
好了,到这里我们也清楚了,原来是MJRefresh给的架构与我们项目的架构不一致导致的,这应该算MJRefresh的锅吧?
很开心,发个包回家了。
第二天测试告诉我,点进所有有下拉刷新的页面 闪退。 What?于是打个release版测试,运行果然报错,
2019-06-21 09:23:44.070 [error][tid:com.facebook.react.JavaScript] Invariant Violation: requireNativeComponent: "RCTMJRefreshView" was not found in the UIManager.
RCTMJRefreshView文件找不到,我查了下,项目里根本就没有这个文件,那肯定在静态库里了,网上给出的解决办法把libRCTMJRefreshHeader.a加到Link Binary With Libraries,这不就又回到原点了?
果断放弃!
再梳理下上面的原因,armv7没有?为什么会没有,项目里已经支持了,看了下MJRefresh也是支持的,仔细检查MJRefresh的配置,iOS Deployment Target 竟然是11.2 ?我的项目是9.0,这是开发者上传环境的失误吧,11.2你支持个鬼哦!
果断改了运行,还是报错,不过错误内容变了:
error: Invalid bitcode signature
clang: error: linker command failed with exit code 1 (use -v to see invocation)
这个报错iOS程序员就很常见了啊,通用型错误,多在加载三方静态库时出现,也是个头疼的问题。
没办法,查吧!
首先有bitcode,看看三方库的Enable Bitcode 跟我项目的一样,YES。那就不改。
网上有说Other Linker Flags加上 -load-all,意思链接所有静态库,试了没用。
还有说是引用文件重复的,但是这种情况一般会报具体文件缺失或有重复定义,那就试一下,把Header Search Paths里的$(SRCROOT)/../node_modules/react-native-mjrefresh/ios/RCTMJRefreshHeader/RCTMJRefreshHeader删掉,运行release,竟然成功了,跑起来也没问题,终于搞好了。
如果不起作用就clean一下或者打开/Users/sj/Library/Developer/Xcode/DerivedData ,把里面的当前项目缓存删掉,再试一下。
最后问题原因应该是版本过高导致库不支持造成的,至于为什么把Header Search Paths引用删了就好了,我也不是很清楚,也许某些文件重复引用了?
有解释不对的地方还望指正。