Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
6
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

React Native で、AndroidのBackボタンの動作を制御する

Posted at

React Nativeで、AndroidのBackボタンで前画面に戻るのを止めたり、確認画面を表示したりする場合にどうすれば最も美しいのかが、人によって言ってることがばらばらだったのでメモ。

環境はReact Native 0.60+Expo+React Navigationでテストしていますが、React Native自体の機能なのでほかの環境でも動作するはず。

BackHandlerを使うべし

 BackHandlerは、React Native本体の機能で、AndroidやtvOSのバックボタン=戻るボタンのイベントを処理できるようにするイベントハンドラー。

 取り扱いが簡単で、React Navigationなどもこのハンドラーの動作に準拠して動作してくれるので、安心して使えます。

使い方

 Backボタンを制御したいコンポーネントコード(関数ではなくクラス化しておくこと)に、以下の順にコードを入れる。

1.BackHandlerをインポート

import { BackHandler } from "react-native";

2.処理を担当するメソッドを追加

  handleBackButton() {
    alert("Hardware back button pressed.")
    return true;    // true: prevent the back action.
  }

ここでtrueを明確に戻していますが、これにより前画面に戻るなど、後に続く処理を抑制しています。falseを戻すと(または何も戻さないと)続く動作を邪魔しません。

3.componentWillMount()にて、上のメソッドを呼ぶイベントリスナーを登録。

  componentWillMount() {
    alert("will mount");
    this.backHandler = BackHandler.addEventListener("hardwareBackPress", this.handleBackButton);
  }

4.componentWillUnmount()にて、コンポーネントがなくなるときにイベントリスナーを解除

  componentWillUnmount(){
    alert("will unmount");
    this.backHandler.remove();
  }

おまけ

BackHandler.exitApp()でアプリを中断できます。

6
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?