2016-04-05 17:55:04 +08:00
|
|
|
|
# 快速入门-准备工作
|
|
|
|
|
|
|
|
|
|
首先你应该有一个基于React Native开发的应用,我们把具有package.json的目录叫做你的"应用根目录"。
|
|
|
|
|
|
2016-04-20 16:27:33 +08:00
|
|
|
|
如果你还没有初始化应用,请参阅[开始使用React Native](http://reactnative.cn/docs/getting-started.html#content)。
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
|
|
|
|
所以我们也假设你已经拥有了开发React Native应用的一切环境,包括`Node.js`、`npm`、`XCode`、`Android SDK`等等。
|
|
|
|
|
|
2016-04-05 22:25:47 +08:00
|
|
|
|
如果你之前没安装过,你还必须安装[Android NDK](http://androiddevtools.cn),并设置环境变量`ANDROID_NDK_HOME`,指向你的NDK根目录(例如`/Users/tdzl2003/Downloads/android-ndk-r10e`)。
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
|
|
|
|
## 安装
|
|
|
|
|
|
|
|
|
|
在你的项目根目录下运行以下命令(不要输入开头的美元符号):
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
$ npm install -g react-native-update-cli rnpm
|
|
|
|
|
$ npm install --save react-native-update
|
|
|
|
|
$ rnpm link react-native-update
|
|
|
|
|
```
|
|
|
|
|
|
2016-04-21 12:28:11 +08:00
|
|
|
|
> * 注意 *
|
|
|
|
|
> 如果访问极慢或者显示网络失败,请使用淘宝镜像并执行`npm config set disturl https://npm.taobao.org/dist`
|
|
|
|
|
|
|
|
|
|
> * Windows平台请注意 *
|
|
|
|
|
> 1、你必须安装python 2.7以及一套C++环境(推荐VS2013或VS2015,VS2010及以前版本不可用)
|
|
|
|
|
> 2、如果使用VS2015,你需要设置`npm config set msvs_version 2015 --global`
|
|
|
|
|
|
2016-04-05 17:55:04 +08:00
|
|
|
|
> 其中第一句,在每一台电脑上仅需运行一次。
|
|
|
|
|
|
|
|
|
|
## 配置Bundle URL(iOS)
|
|
|
|
|
|
|
|
|
|
// 文档建设中
|
|
|
|
|
|
2016-04-06 00:51:22 +08:00
|
|
|
|
在工程target的Build Phases->Link Binary with Libraries中加入libz.tbd、libbz2.1.0.tbd
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
在你的AppDelegate.m文件中增加如下代码:
|
|
|
|
|
|
|
|
|
|
```objective-c
|
|
|
|
|
// ... 其它代码
|
|
|
|
|
|
|
|
|
|
#import "RCTHotUpdate.h"
|
|
|
|
|
|
|
|
|
|
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
|
|
|
|
{
|
2016-04-18 11:02:15 +08:00
|
|
|
|
#if DEBUG
|
|
|
|
|
// 原来的jsCodeLocation
|
|
|
|
|
jsCodeLocation = [NSURL URLWithString:@"http://localhost:8081/index.ios.bundle?platform=ios&dev=true"];
|
|
|
|
|
#else
|
|
|
|
|
jsCodeLocation=[RCTHotUpdate bundleURL];
|
|
|
|
|
#endif
|
|
|
|
|
// ... 其它代码
|
2016-04-06 00:51:22 +08:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2016-04-05 17:55:04 +08:00
|
|
|
|
## 配置Bundle URL(Android)
|
|
|
|
|
|
|
|
|
|
在你的ReactActivity中增加如下代码:
|
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
// ... 其它代码
|
|
|
|
|
|
|
|
|
|
import cn.reactnative.modules.update.UpdateContext;
|
|
|
|
|
|
|
|
|
|
public class MainActivity extends ReactActivity {
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
protected String getJSBundleFile() {
|
|
|
|
|
return UpdateContext.getBundleUrl(this);
|
|
|
|
|
}
|
|
|
|
|
// ... 其它代码
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 登录与创建应用
|
|
|
|
|
|
|
|
|
|
在你的项目根目录下运行以下命令:
|
|
|
|
|
|
|
|
|
|
```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)
|
2016-04-05 20:07:23 +08:00
|
|
|
|
3) 招财旺(ios)
|
2016-04-05 17:55:04 +08:00
|
|
|
|
|
2016-04-05 20:07:23 +08:00
|
|
|
|
Total 2 ios apps
|
2016-04-05 17:55:04 +08:00
|
|
|
|
Enter appId: <输入应用前面的编号>
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
选择或者创建过应用后,你将可以在文件夹下看到`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)
|