关闭

React Native发布APP之打包iOS应用

标签: ios发布app打包发布rn打包发布
8236人阅读 评论(0) 收藏 举报
分类:

了解更多,可学习《React Native视频教程》
,或关注我的GitHub和加入:
React Native学习交流群

React Native学习交流群


用React Native开发好APP之后,如何将APP发布以供用户使用呢?一款APP的发布流程无外乎:签名打包—>发布到各store这两大步骤。本文将向大家分享如何签名打包一款React Native APP。

在本文中我将为大家讲解如何打包和发布React Native iOS App。

第一步:导出js bundle包和图片资源

和打包React Native Android应用不同的是,我们无法通过命令一步进行导出React Native iOS应用。我们需要将JS部分的代码和图片资源等打包导出,然后通过XCode将其添加到iOS项目中。

导出js bundle的命令

在React Native项目的根目录下执行:

react-native bundle --entry-file index.ios.js --platform ios --dev false --bundle-output release_ios/main.jsbundle --assets-dest release_ios/

通过上述命令,我们可以将JS部分的代码和图片资源等打包导出到release_ios目录下:

生成jsbundle

其中,assets为项目中的JS部分所用到的图片资源(不包括原生模块中的图片资源),main.jsbundle是JS部分的代码。

在执行打包命令之前,我们需要先确保在我们项目的根目录有release_ios文件夹,没有的话创建一个。

第二步:将js bundle包和图片资源导入到iOS项目中

这一步我们需要用到XCode,选择assets文件夹与main.jsbundle文件将其拖拽到XCode的项目导航面板中即可。

导入jsbundle

然后,修改AppDelegate.m文件,添加如下代码:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{

  NSURL *jsCodeLocation;
 //jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];
 +jsCodeLocation = [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
#endif
...
  return YES;
}

上述代码的作用是让React Native去使用我们刚才导入的jsbundle,这样以来我们就摆脱了对本地nodejs服务器的依赖。

提示:如果在项目中使用了CodePush热更新,那么我们需要就可以直接通过CodePush来读取本地的jsbundle,方法如下:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
  NSURL *jsCodeLocation;  
#ifdef DEBUG
    jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];
#else
    jsCodeLocation = [CodePush bundleURL];
#endif
...
  return YES;
}

到目前为止呢,我们已经将js bundle包和图片资源导入到iOS项目中,接下来我们就可以发布我们的iOS应用了。

第三步:发布iOS应用

发布iOS应用我们需要有一个99美元的账号用于将App上传到AppStore,或者是299美元的企业级账号用于将App发布到自己公司的服务器或第三方公司的服务器。

接下来我们就需要进行申请APPID ➜ 在Tunes Connect创建应用 ➜ 打包程序 ➜ 将应用提交到app store等几大步骤。

因为官方文档中有详细的说明,在这我就不再重复了。

如果,大家在打包发布React Native iOS应用的过程中遇到问题可以在本文的下方进行留言,我看到了后会及时回复的哦。
另外也可以关注我的新浪微博,或者关注我的Github来获取更多有关React Native开发的技术干货

推荐学习:视频教程《React Native开发跨平台GitHub App》

4
2
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

React Native发布APP之签名打包APK

用React Native开发好APP之后,如何将APP发布以供用户使用呢?一款APP的发布流程无外乎:签名打包—>发布到各store这两大步骤。本文将向大家分享如何签名打包一款React Nativ...
  • fengyuzhengfan
  • fengyuzhengfan
  • 2016-07-19 19:44
  • 9723

react-native ios端真机调试 打包与发布

最近做了一个项目,用的react-native 开发的iso项目。 由于自己没有oc基础,所以该项目几乎全用js写得。(顺便说一下,react-native 开发,最好还是学一下原生,起码的看得懂,不...
  • jiejiegua
  • jiejiegua
  • 2017-01-22 16:29
  • 4568

React-Native工程项目打包编译发布过程详解

前言现在大红大紫的React-Native框架热度可谓与日俱增,React-Native的热更新操作,在开发过程中的确带来很多好处,但是对于发布来讲,不同平台却不尽相同, 下面来具体看一下Androi...
  • jiangbo_phd
  • jiangbo_phd
  • 2017-01-03 19:51
  • 5756

React Native发布APP之打包iOS应用

用React Native开发好APP之后,如何将APP发布以供用户使用呢?一款APP的发布流程无外乎:签名打包—>发布到各store这两大步骤。本文将向大家分享如何签名打包一款React Nativ...
  • sinat_17775997
  • sinat_17775997
  • 2017-05-09 09:13
  • 507

FB开源React Native,用JS开发原生iOS应用

原文地址:http://www.cocoachina.com/ios/20150327/11439.html Facebook今日正式开源了React Native库,目前已经可在git...
  • zspirtmoonyy
  • zspirtmoonyy
  • 2015-04-06 21:13
  • 807

通过React Native动态更新iOS应用

本文属原创,转载请注明出处,谢谢!  这篇文章一直拖了快1个多月了,一直都找借口不去完成它。今天终于铁了心了。开始正题。  做 iOS 开发的都知道,和 Android 开发不同,在提交 Ap...
  • xu_song
  • xu_song
  • 2016-11-22 15:52
  • 1384

通过React Native动态更新iOS应用

这篇文章一直拖了快1个多月了,一直都找借口不去完成它。今天终于铁了心了。开始正题。 这是一篇关于 react-native iOS 动态更新的文章。
  • linshaolie
  • linshaolie
  • 2016-03-23 12:05
  • 3722

AIR Native Extension实现iOS应用内付费(In-App Purchase)全教程(四)——ANE面向IAP的测试和开发

本文的内容如下: 在Native扩展中使用StoreKit框架 ActionScript扩展 ANE-IAP开发实例分享 本文用到的工具和设备如下: Flash Builder ...
  • wkyb608
  • wkyb608
  • 2011-10-08 13:32
  • 672

AIR Native Extension实现iOS应用内付费(In-App Purchase)全教程(四)——ANE面向IAP的测试和开发

本文的内容如下: 在Native扩展中使用StoreKit框架 ActionScript扩展 ANE-IAP开发实例分享 本文用到的工具和设备如下: Flash Builder ...
  • yu0089
  • yu0089
  • 2012-09-28 10:00
  • 2012

AIR Native Extension实现iOS应用内付费(In-App Purchase)全教程(一)——概览

阅读本文的基础 ActionScript 3.0编程基础 Apple iOS开发者权限 前言 记得在写Flash开发iOS应用全攻略的时候,不少感兴趣的朋友询问Flash技术是否能...
  • wkyb608
  • wkyb608
  • 2011-10-08 13:30
  • 466
    个人资料
    • 访问:980859次
    • 积分:12010
    • 等级:
    • 排名:第1439名
    • 原创:181篇
    • 转载:4篇
    • 译文:0篇
    • 评论:225条
    这里有你需要的干货!!!
    关注我,获取推送O_o
    你需要的,才是干货@开源项目
    博客专栏
    最新评论