web-dev-qa-db-ja.com

Reactネイティブアプリが閉じられている(中断されていない)ことを検出する方法は?

私はあちこちを見て、これに対する答えを見つけることができません。ユーザーが自分のReactネイティブアプリを閉じようとしていることを検出するにはどうすればよいですか(プロセスの実行中、アプリを手動で管理し、強制終了する)。ログアウトを追加したいAppStateは、アプリがバックグラウンドに出入りしたときのみ検出するように見えます。

39
Dale_Plante

前の状態を検出して、次の状態と比較できるようです。私がオンラインで見つけることができるものから、アプリが閉じているのかバックグラウンドに入るのかを検出することはできませんが、inactive(閉じている)かbackgroundにあるかを検出できます。

React Native Docs の例

import React, {Component} from 'react'
import {AppState, Text} from 'react-native'

class AppStateExample extends Component {

  state = {
    appState: AppState.currentState
  }

  componentDidMount() {
    AppState.addEventListener('change', this._handleAppStateChange);
  }

  componentWillUnmount() {
    AppState.removeEventListener('change', this._handleAppStateChange);
  }

  _handleAppStateChange = (nextAppState) => {
    if (this.state.appState.match(/inactive|background/) && nextAppState === 'active') {
      console.log('App has come to the foreground!')
    }
    this.setState({appState: nextAppState});
  }

  render() {
    return (
      <Text>Current state is: {this.state.appState}</Text>
    );
  }

}
17
user888750

簡単な方法として、アプリが閉じられたことを検出するためにroot component内でcomponentWillUnmount()を使用できます。ルートコンポーネントは、アプリが閉じられたときにのみアンマウントされるためです。 :)

0
Rid