2016-04-05 17:55:04 +08:00
|
|
|
|
# 快速入门-准备工作
|
|
|
|
|
|
|
|
|
|
首先你应该有一个基于React Native开发的应用,我们把具有package.json的目录叫做你的"应用根目录"。
|
|
|
|
|
|
2019-04-15 18:04:03 +08:00
|
|
|
|
如果你还没有初始化应用,请参阅[开始使用React Native](https://reactnative.cn/docs/getting-started.html#content)。
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
|
|
|
|
所以我们也假设你已经拥有了开发React Native应用的一切环境,包括`Node.js`、`npm`、`XCode`、`Android SDK`等等。
|
|
|
|
|
|
|
|
|
|
## 安装
|
|
|
|
|
|
2016-11-26 12:24:17 +08:00
|
|
|
|
在你的项目根目录下运行以下命令:
|
2016-08-17 21:25:11 +08:00
|
|
|
|
|
2016-04-05 17:55:04 +08:00
|
|
|
|
```bash
|
2018-07-20 17:01:12 +08:00
|
|
|
|
npm i -g react-native-update-cli
|
2019-09-05 18:41:00 +08:00
|
|
|
|
npm i react-native-update
|
2016-04-21 14:17:58 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-09-05 18:41:00 +08:00
|
|
|
|
> 如果下载极慢或者显示网络失败,请设置使用淘宝镜像`npx nrm use taobao`
|
2019-07-05 00:52:00 +08:00
|
|
|
|
|
2019-09-05 18:41:00 +08:00
|
|
|
|
如果你的RN版本 >= 0.60,请在iOS目录下执行:
|
2016-04-21 12:28:33 +08:00
|
|
|
|
|
2016-08-17 21:25:11 +08:00
|
|
|
|
```bash
|
2019-09-05 18:41:00 +08:00
|
|
|
|
pod install
|
2016-08-17 21:25:11 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
如果你的RN版本 < 0.60,那么还需要[手动link](#一手动link)
|
2019-09-05 18:41:00 +08:00
|
|
|
|
|
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
<details>
|
|
|
|
|
<summary>
|
|
|
|
|
如果你的RN版本比较老(< 0.46),请点击这里的注意事项
|
|
|
|
|
</summary>
|
2016-06-27 21:02:47 +08:00
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
如果你的RN版本比较老,请按下面表格尝试老一些的版本(但这些版本我们已不再维护,不能保证可以使用):
|
2016-08-17 21:25:11 +08:00
|
|
|
|
|
2018-06-01 15:03:00 +08:00
|
|
|
|
| React Native版本 | react-native-update版本 |
|
|
|
|
|
| ---------------- | ----------------------- |
|
|
|
|
|
| 0.26及以下 | 1.0.x |
|
|
|
|
|
| 0.27 - 0.28 | 2.x |
|
|
|
|
|
| 0.29 - 0.33 | 3.x |
|
|
|
|
|
| 0.34 - 0.45 | 4.x |
|
2017-07-14 11:31:55 +08:00
|
|
|
|
|
2016-11-26 12:24:17 +08:00
|
|
|
|
安装命令示例:
|
|
|
|
|
```
|
2019-09-05 18:50:03 +08:00
|
|
|
|
npm i react-native-update@4.x
|
2016-04-21 14:17:58 +08:00
|
|
|
|
```
|
2016-04-21 12:28:11 +08:00
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
如果RN的版本是0.45及以下,你还必须安装[Android NDK](http://androiddevtools.cn),版本最好选用r10e,并设置环境变量`ANDROID_NDK_HOME`,指向你的NDK根目录(例如`/Users/tdzl2003/Downloads/android-ndk-r10e`)。
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
请记得一定要重新编译(react-native run-ios或run-android命令编译,或在Xcode/Android Studio中重新编译)。
|
|
|
|
|
|
|
|
|
|
|
2019-12-29 12:36:08 +08:00
|
|
|
|
## 手动link
|
2016-04-21 12:28:11 +08:00
|
|
|
|
|
2019-09-05 18:41:00 +08:00
|
|
|
|
如果RN版本 >= 0.60则可以跳过此步骤
|
2016-08-17 21:25:11 +08:00
|
|
|
|
|
2018-06-01 15:03:00 +08:00
|
|
|
|
### iOS
|
2016-08-17 21:25:11 +08:00
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
<details>
|
2019-09-05 18:41:00 +08:00
|
|
|
|
<summary>RN < 0.60且使用CocoaPods(推荐)</summary>
|
|
|
|
|
|
|
|
|
|
1. 在ios/Podfile中添加
|
|
|
|
|
```
|
|
|
|
|
pod 'react-native-update', path: '../node_modules/react-native-update'
|
|
|
|
|
```
|
|
|
|
|
2. 在项目的ios目录下运行`pod install`
|
|
|
|
|
3. 重新编译
|
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
</details>
|
2019-09-05 18:41:00 +08:00
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
<details>
|
2019-09-05 18:41:00 +08:00
|
|
|
|
<summary>RN < 0.60且不使用CocoaPods</summary>
|
|
|
|
|
|
2016-08-17 21:25:11 +08:00
|
|
|
|
1. 在XCode中的Project Navigator里,右键点击`Libraries` ➜ `Add Files to [你的工程名]`
|
2019-11-16 00:31:30 +08:00
|
|
|
|
2. 进入`node_modules` ➜ `react-native-update` ➜ `ios 并选中 `RCTPushy.xcodeproj`
|
|
|
|
|
3. 在XCode中的project navigator里,选中你的工程,在 `Build Phases` ➜ `Link Binary With Libraries` 中添加 `libRCTPushy.a`
|
2017-03-01 17:23:35 +08:00
|
|
|
|
4. 继续在`Build Settings`里搜索`Header Search Path`,添加$(SRCROOT)/../node_modules/react-native-update/ios
|
2019-12-14 12:24:39 +08:00
|
|
|
|
5. 在`Build Phases`添加一个`New Run Script Phase`运行脚本,内容如下
|
|
|
|
|
```
|
|
|
|
|
#!/bin/bash
|
|
|
|
|
set -x
|
|
|
|
|
DEST="../node_modules/react-native-update/ios/"
|
|
|
|
|
date +%s > "$DEST/pushy_build_time.txt"
|
|
|
|
|
```
|
2019-12-14 12:26:04 +08:00
|
|
|
|
编译的时候就会在`../node_modules/react-native-update/ios/`文件夹下面生成一个`pushy_build_time.txt`文件。
|
2019-12-14 12:24:39 +08:00
|
|
|
|
然后在`Copy Bundle Resources`里把生成的`pushy_build_time.txt`文件添加进去。
|
2019-12-14 12:26:04 +08:00
|
|
|
|
|
2019-12-14 12:24:39 +08:00
|
|
|
|
6. 重新编译
|
2019-09-05 18:41:00 +08:00
|
|
|
|
|
2019-09-05 18:50:03 +08:00
|
|
|
|
</details>
|
2016-08-17 21:25:11 +08:00
|
|
|
|
|
2018-06-01 15:03:00 +08:00
|
|
|
|
### Android
|
2016-04-21 14:17:58 +08:00
|
|
|
|
|
2019-09-05 18:55:01 +08:00
|
|
|
|
|
|
|
|
|
<details>
|
|
|
|
|
<summary>RN < 0.60</summary>
|
2016-08-17 21:25:11 +08:00
|
|
|
|
1. 在`android/settings.gradle`中添加如下代码:
|
|
|
|
|
```
|
|
|
|
|
include ':react-native-update'
|
|
|
|
|
project(':react-native-update').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-update/android')
|
|
|
|
|
```
|
2018-06-01 15:03:00 +08:00
|
|
|
|
|
2016-08-17 21:25:11 +08:00
|
|
|
|
2. 在`android/app/build.gradle`的 dependencies 部分增加如下代码:
|
|
|
|
|
```
|
2019-07-05 00:52:00 +08:00
|
|
|
|
implementation project(':react-native-update')
|
2016-08-17 21:25:11 +08:00
|
|
|
|
```
|
2018-06-01 15:03:00 +08:00
|
|
|
|
|
2019-07-06 22:44:09 +08:00
|
|
|
|
3. 打开`android/app/src/main/java/[...]/MainApplication.java`,
|
2016-08-17 21:25:11 +08:00
|
|
|
|
- 在文件开头增加 `import cn.reactnative.modules.update.UpdatePackage;`
|
|
|
|
|
- 在`getPackages()` 方法中增加 `new UpdatePackage()`(注意上一行可能要增加一个逗号)
|
2019-09-05 18:55:01 +08:00
|
|
|
|
</details>
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
2019-12-29 12:36:08 +08:00
|
|
|
|
## 配置Bundle URL
|
2018-06-01 15:03:00 +08:00
|
|
|
|
|
2019-07-05 00:52:00 +08:00
|
|
|
|
注意此步骤无论任何版本,目前都需要手动配置。
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
2019-07-05 00:52:00 +08:00
|
|
|
|
### iOS
|
2016-04-06 00:51:22 +08:00
|
|
|
|
|
2019-07-06 22:44:09 +08:00
|
|
|
|
1. (RN >= 0.60或者使用CocoaPods集成此步可跳过)在工程target的Build Phases->Link Binary with Libraries中加入`libz.tbd`、`libbz2.1.0.tbd`
|
2016-04-06 00:51:22 +08:00
|
|
|
|
|
2019-07-05 00:52:00 +08:00
|
|
|
|
2. 在你的AppDelegate.m文件中增加如下代码:
|
2016-04-06 00:51:22 +08:00
|
|
|
|
|
|
|
|
|
```objective-c
|
|
|
|
|
// ... 其它代码
|
|
|
|
|
|
2019-11-16 00:31:30 +08:00
|
|
|
|
#import "RCTPushy.h"
|
2016-04-06 00:51:22 +08:00
|
|
|
|
|
2019-07-06 22:44:09 +08:00
|
|
|
|
// 如果RN版本 >= 0.59,修改sourceURLForBridge
|
|
|
|
|
- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
|
|
|
|
|
{
|
|
|
|
|
#if DEBUG
|
|
|
|
|
return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
|
|
|
|
|
#else
|
|
|
|
|
// 非DEBUG情况下替换为热更新bundle
|
2019-11-16 00:31:30 +08:00
|
|
|
|
return [RCTPushy bundleURL];
|
2019-07-06 22:44:09 +08:00
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 如果RN版本 < 0.59,修改didFinishLaunchingWithOptions
|
2016-04-06 00:51:22 +08:00
|
|
|
|
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
|
|
|
|
{
|
2016-04-18 11:02:15 +08:00
|
|
|
|
#if DEBUG
|
2018-01-03 16:30:01 +08:00
|
|
|
|
// 原来的jsCodeLocation保留在这里
|
|
|
|
|
jsCodeLocation = ..........
|
2016-04-18 11:02:15 +08:00
|
|
|
|
#else
|
2019-07-06 22:44:09 +08:00
|
|
|
|
// 非DEBUG情况下替换为热更新bundle
|
2019-11-16 00:31:30 +08:00
|
|
|
|
jsCodeLocation = [RCTPushy bundleURL];
|
2016-04-18 11:02:15 +08:00
|
|
|
|
#endif
|
|
|
|
|
// ... 其它代码
|
2016-04-06 00:51:22 +08:00
|
|
|
|
}
|
2019-07-06 22:44:09 +08:00
|
|
|
|
|
2016-04-06 00:51:22 +08:00
|
|
|
|
```
|
|
|
|
|
|
2018-06-01 15:03:00 +08:00
|
|
|
|
### Android
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
2019-07-06 22:44:09 +08:00
|
|
|
|
在MainApplication中增加如下代码:
|
2016-07-11 18:57:43 +08:00
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
// ... 其它代码
|
|
|
|
|
|
2018-06-01 15:03:00 +08:00
|
|
|
|
// 请注意不要少了这句import
|
2016-07-11 18:57:43 +08:00
|
|
|
|
import cn.reactnative.modules.update.UpdateContext;
|
|
|
|
|
public class MainApplication extends Application implements ReactApplication {
|
|
|
|
|
|
|
|
|
|
private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
|
|
|
|
|
@Override
|
|
|
|
|
protected String getJSBundleFile() {
|
2016-07-11 19:09:14 +08:00
|
|
|
|
return UpdateContext.getBundleUrl(MainApplication.this);
|
2016-07-11 18:57:43 +08:00
|
|
|
|
}
|
|
|
|
|
// ... 其它代码
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2019-12-29 12:36:08 +08:00
|
|
|
|
## 登录与创建应用
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
2019-04-15 18:04:03 +08:00
|
|
|
|
首先请在<https://update.reactnative.cn>注册帐号,然后在你的项目根目录下运行以下命令:
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
$ pushy login
|
|
|
|
|
email: <输入你的注册邮箱>
|
|
|
|
|
password: <输入你的密码>
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
这会在项目文件夹下创建一个`.update`文件,注意不要把这个文件上传到Git等CVS系统上。你可以在`.gitignore`末尾增加一行`.update`来忽略这个文件。
|
|
|
|
|
|
|
|
|
|
登录之后可以创建应用。注意iOS平台和安卓平台需要分别创建:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
$ pushy createApp --platform ios
|
|
|
|
|
App Name: <输入应用名字>
|
|
|
|
|
$ pushy createApp --platform android
|
|
|
|
|
App Name: <输入应用名字>
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
> 两次输入的名字可以相同,这没有关系。
|
|
|
|
|
|
|
|
|
|
如果你已经在网页端或者其它地方创建过应用,也可以直接选择应用:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
$ pushy selectApp --platform ios
|
|
|
|
|
1) 鱼多多(ios)
|
2019-07-06 22:44:09 +08:00
|
|
|
|
2) 招财旺(ios)
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
2016-04-05 20:07:23 +08:00
|
|
|
|
Total 2 ios apps
|
2017-10-19 17:41:34 +08:00
|
|
|
|
Enter appId: <输入应用前面的编号>
|
2016-04-05 17:55:04 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
选择或者创建过应用后,你将可以在文件夹下看到`update.json`文件,其内容类似如下形式:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
{
|
|
|
|
|
"ios": {
|
|
|
|
|
"appId": 1,
|
|
|
|
|
"appKey": "<一串随机字符串>"
|
|
|
|
|
},
|
|
|
|
|
"android": {
|
|
|
|
|
"appId": 2,
|
|
|
|
|
"appKey": "<一串随机字符串>"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2016-04-08 14:51:41 +08:00
|
|
|
|
你可以安全的把`update.json`上传到Git等CVS系统上,与你的团队共享这个文件,它不包含任何敏感信息。当然,他们在使用任何功能之前,都必须首先输入`pushy login`进行登录。
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
|
|
|
|
至此应用的创建/选择就已经成功了。下一步,你需要给代码添加相应的功能,请参阅[添加热更新功能](guide2.md)
|