资讯专栏INFORMATION COLUMN

React Native 0.29.0版本iOS端BundleURL加载方法

liukai90 / 3228人阅读

摘要:在版本中加载方法做了重大改变,新增了单例类专门处理,使用保存配置信息。非模式时,没有文件,会直接读取本地文件,和以前版本的方式相同。手动设置在接口中暴露了属性,可以通过手动设置。另需要在设置的为即可。

React Native iOS在0.29.0版本中BundleURL加载方法做了重大改变,新增了RCTBundleURLProvider单例类专门处理BundleURL,使用NSUserDefaults保存配置信息。

默认加载方式

在Debug模式下,执行react-native-xcode.sh编译脚本会自动获取当前网卡en0的IP地址,并打入App包中一个配置文件ip.txt,App运行时会读取ip文件,自动生成Developer Server URL,通过这种加载方式,我们不再需要手动去把"localhost"改成Mac的IP了,每次编译都会读取当前最新的IP。

if [[ "$CONFIGURATION" = "Debug" && "$PLATFORM_NAME" != "iphonesimulator" ]]; then
  PLISTBUDDY="/usr/libexec/PlistBuddy"
  PLIST=$TARGET_BUILD_DIR/$INFOPLIST_PATH
  IP=$(ipconfig getifaddr en0)
  $PLISTBUDDY -c "Add NSAppTransportSecurity:NSExceptionDomains:localhost:NSTemporaryExceptionAllowsInsecureHTTPLoads bool true" $PLIST
  $PLISTBUDDY -c "Add NSAppTransportSecurity:NSExceptionDomains:$IP.xip.io:NSTemporaryExceptionAllowsInsecureHTTPLoads bool true" $PLIST
  echo "$IP.xip.io" > "$DEST/ip.txt"
fi

非Debug模式时,没有ip.txt文件,会直接读取本地jsbundle文件,和以前版本的Load from pre-bundled file on disk方式相同。
但是我经过测试发现,en0是Wifi的网络,如果关闭Wifi,使用网线端口连接网络,en0默认就是inactive,没有对应的IP。

手动设置IP

RCTBundleURLProvider在接口中暴露了jsLocation属性,可以通过setJsLocation手动设置IP。

NSURL *jsCodeLocation;

[[RCTBundleURLProvider sharedSettings] setDefaults];
#if DEBUG
[[RCTBundleURLProvider sharedSettings] setJsLocation:@"192.168.1.101"];
#endif
jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];

另需要在Info设置NSAppTransportSecurityNSAllowsArbitraryLoadstrue即可。

总之

RCTBundleURLProvider类做了一些消息和属性的封装,可以通过判断是否DEBUG环境然后做不同的设置。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/16337.html

相关文章

  • React Native 0.29.0版本iOSBundleURL加载方法

    摘要:在版本中加载方法做了重大改变,新增了单例类专门处理,使用保存配置信息。非模式时,没有文件,会直接读取本地文件,和以前版本的方式相同。手动设置在接口中暴露了属性,可以通过手动设置。另需要在设置的为即可。 React Native iOS在0.29.0版本中BundleURL加载方法做了重大改变,新增了RCTBundleURLProvider单例类专门处理BundleURL,使用NSUse...

    spacewander 评论0 收藏0
  • 关于weex

    摘要:在最上面的,阿里一般称之为文件,通过转换成,再部署到服务器,这样服务端就完成了。例如,通过安装了业界的工具库用上和如今前端的开发,一般离不开预处理器,比如和。在默认的文件中,即使有的助力,这类预处理器也是对其无能为力的。 生命周期 module.exports = { data: {}, methods: {}, init: function () { ...

    chadLi 评论0 收藏0
  • 加推Weex实践之路(上)

    摘要:我们参考小程序的设计思路进行了优化升级,为每一个需要特有化配置的页面添加一个格式的配置文件,配置文件包括导航栏的配置页面级别的配置跳转的配置等,将配置工程化标准化。设置导航栏按钮包含按钮样式的数组通过完成按钮事件的回调。一、背景1.为什么是Weex在公司快速发展的大环境下,App的更新迭代高速、高频,技术团队平均两周便可诞生一款中型App,但App团队只有6个人(iOS 、Android各3...

    shuibo 评论0 收藏0
  • codepush使用记录

    摘要:中文翻译中文翻译常用命令安装注册账号登陆注销添加项目名称删除项目名称列出账号下的所有项目显示登陆的删除某个添加协作人员部署一个环境删除部署列出应用的部署查询部署环境的查看部署的历史版本信息重命名一 CodePush中文翻译 CodePush中文翻译 1. code-push常用命令 安装: npm install -g code-push-cli 注册账号: code-push re...

    xiaokai 评论0 收藏0
  • iOS原生混合RN开发最佳实践

    摘要:交流群也定期更新最新的学习资料给大家,谢谢大家支持小伙伴们扫下方二维码加入技术交流群 iOS原生混合RN开发详解 做过原生iOS开发或者Android开发的同学们肯定也都了解Hybrid,有一些Hybrid的开发经验,目前我们企业开发中运用最广泛的Hybrid App技术就是原生与H5 hybrid,在早期的时候,可能部分同学也接触过PhoneGap等hybrid技术,今天我们就简单来...

    B0B0 评论0 收藏0

发表评论

0条评论

liukai90

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<