跳到主要内容

AppState

AppState 可以告诉你应用是在前台还是后台运行,并在状态改变时通知你。

AppState 常用于确定处理推送通知时的意图和正确行为。

应用状态

  • active - 应用正在前台运行
  • background - 应用正在后台运行。用户可能:
    • 在另一个应用中
    • 在主屏幕上
    • [Android] 在另一个 Activity 中(即使它是由你的应用启动的)
  • [iOS] inactive - 这是在前台与后台之间切换、以及在非活动期间(如进入多任务视图、打开通知中心或有来电时)发生的状态。

更多信息,请参阅 Apple 的文档

基本用法

要查看当前状态,你可以检查 AppState.currentState,它会保持最新。然而,在应用启动时,currentState 将为 null,因为 AppState 正在通过桥接获取它。

此示例将始终显示“当前状态为:active”,因为应用仅在处于 active 状态时对用户可见,并且 null 状态只会短暂出现。如果你想尝试此代码,我们建议使用你自己的设备而不是嵌入式预览。


参考

事件

change

当应用状态发生变化时,会收到此事件。侦听器会收到当前应用状态值之一的调用。

memoryWarning

此事件用于在需要抛出内存警告或释放内存时。

focus
Android

当应用获得焦点时(用户正在与应用交互)收到此事件。

blur
Android

当用户未主动与应用交互时收到此事件。在用户下拉通知抽屉的情况下很有用。AppState 不会改变,但会触发 blur 事件。

方法

addEventListener()

tsx
static addEventListener(
type: AppStateEvent,
listener: (state: AppStateStatus) => void,
): NativeEventSubscription;

设置一个函数,当 AppState 上发生指定事件类型时,该函数将被调用。eventType 的有效值在上面列出。返回 EventSubscription

属性

currentState

tsx
static currentState: AppStateStatus;