跳到主要内容
版本:0.81

AppRegistry

AppRegistry 是运行所有 React Native 应用的 JS 入口点。应用根组件应该通过 AppRegistry.registerComponent 注册自己,然后原生系统可以加载应用的 bundle,并在准备就绪时通过调用 AppRegistry.runApplication 实际运行应用。

tsx
import {Text, AppRegistry} from 'react-native';

const App = () => (
<View>
<Text>App1</Text>
</View>
);

AppRegistry.registerComponent('Appname', () => App);

要在视图应该被销毁时“停止”应用,请使用传递给 runApplication 的 tag 调用 AppRegistry.unmountApplicationComponentAtRootTag。这两个应该总是成对使用。

AppRegistry 应该在 require 序列的早期被引入,以确保在其他模块被引入之前设置好 JS 执行环境。


参考

方法

getAppKeys()

tsx
static getAppKeys(): string[];

返回一个字符串数组。


getRegistry()

tsx
static getRegistry(): {sections: string[]; runnables: Runnable[]};

返回一个 Registry 对象。


getRunnable()

tsx
static getRunnable(appKey: string): : Runnable | undefined;

返回一个 Runnable 对象。

参数:

名称类型
appKey
必需
string

getSectionKeys()

tsx
static getSectionKeys(): string[];

返回一个字符串数组。


getSections()

tsx
static getSections(): Record<string, Runnable>;

返回一个 Runnables 对象。


registerCancellableHeadlessTask()

tsx
static registerCancellableHeadlessTask(
taskKey: string,
taskProvider: TaskProvider,
taskCancelProvider: TaskCancelProvider,
);

注册一个可以取消的 headless 任务。headless 任务是一段没有 UI 运行的代码。

参数:

名称类型描述
taskKey
必需
string调用 startHeadlessTask 时使用的此任务实例的原生 id。
taskProvider
必需
TaskProvider一个返回 promise 的函数,它将从原生侧传递的一些数据作为唯一参数。当 promise 被 resolve 或 reject 时,原生侧会收到此事件通知,并可能决定销毁 JS 上下文。
taskCancelProvider
必需
TaskCancelProvider一个不返回值的函数,不接受参数;当请求取消时,由 taskProvider 执行的函数应该结束并尽快返回。

registerComponent()

tsx
static registerComponent(
appKey: string,
getComponentFunc: ComponentProvider,
section?: boolean,
): string;

参数:

名称类型
appKey
必需
string
componentProvider
必需
ComponentProvider
sectionboolean

registerConfig()

tsx
static registerConfig(config: AppConfig[]);

参数:

名称类型
config
必需
AppConfig[]

registerHeadlessTask()

tsx
static registerHeadlessTask(
taskKey: string,
taskProvider: TaskProvider,
);

注册一个 headless 任务。headless 任务是一段没有 UI 运行的代码。

这是一种在应用处于后台时在 JavaScript 中运行任务的方法。例如,它可以用于同步最新数据、处理推送通知或播放音乐。

参数:

名称类型描述
taskKey
必需
string调用 startHeadlessTask 时使用的此任务实例的原生 id。
taskProvider
必需
TaskProvider一个返回 promise 的函数,它将从原生侧传递的一些数据作为唯一参数。当 promise 被 resolve 或 reject 时,原生侧会收到此事件通知,并可能决定销毁 JS 上下文。

registerRunnable()

tsx
static registerRunnable(appKey: string, func: Runnable): string;

参数:

名称类型
appKey
必需
string
run
必需
function

registerSection()

tsx
static registerSection(
appKey: string,
component: ComponentProvider,
);

参数:

名称类型
appKey
必需
string
component
必需
ComponentProvider

runApplication()

tsx
static runApplication(appKey: string, appParameters: any): void;

加载 JavaScript bundle 并运行应用。

参数:

名称类型
appKey
必需
string
appParameters
必需
any

setComponentProviderInstrumentationHook()

tsx
static setComponentProviderInstrumentationHook(
hook: ComponentProviderInstrumentationHook,
);

参数:

名称类型
hook
必需
function

有效的 hook 函数接受以下内容作为参数:

名称类型
component
必需
ComponentProvider
scopedPerformanceLogger
必需
IPerformanceLogger

该函数还必须返回一个 React Component。


setWrapperComponentProvider()

tsx
static setWrapperComponentProvider(
provider: WrapperComponentProvider,
);

参数:

名称类型
provider
必需
ComponentProvider

startHeadlessTask()

tsx
static startHeadlessTask(
taskId: number,
taskKey: string,
data: any,
);

仅从原生代码调用。启动一个 headless 任务。

参数:

名称类型描述
taskId
必需
number此任务实例的原生 id,用于跟踪其执行。
taskKey
必需
string要启动的任务的键。
data
必需
any传递给任务的数据。

unmountApplicationComponentAtRootTag()

tsx
static unmountApplicationComponentAtRootTag(rootTag: number);

当视图应该被销毁时停止应用。

参数:

名称类型
rootTag
必需
number

类型定义

AppConfig

用于 registerConfig 方法的应用程序配置。

类型
object

属性:

名称类型
appKey
必需
string
componentComponentProvider
runfunction
sectionboolean

注意: 每个配置都应设置 componentrun 函数。

Registry

类型
object

属性:

名称类型
runnablesRunnables 数组
sections字符串数组

Runnable

类型
object

属性:

名称类型
componentComponentProvider
runfunction

Runnables

一个对象,其键为 appKey,值为 Runnable 类型。

类型
object

Task

Task 是一个函数,它接受任何数据作为参数,并返回一个解析为 undefined 的 Promise。

类型
function

TaskCanceller

TaskCanceller 是一个不接受参数且返回 void 的函数。

类型
function

TaskCancelProvider

有效的 TaskCancelProvider 是一个返回 TaskCanceller 的函数。

类型
function

TaskProvider

有效的 TaskProvider 是一个返回 Task 的函数。

类型
function