美文网首页
libRCTMJRefreshHeader.a找不到问题解决

libRCTMJRefreshHeader.a找不到问题解决

作者: geniu_vs | 来源:发表于2019-06-21 14:07 被阅读0次

    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引用删了就好了,我也不是很清楚,也许某些文件重复引用了?

    有解释不对的地方还望指正。

    相关文章

      网友评论

          本文标题:libRCTMJRefreshHeader.a找不到问题解决

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