React Native学习之Android的返回键BackAndroid详解

前言

最近在学习使用 React Native开发,iOS搞完,开始适配安卓,由于木有接触过安卓,所以碰到了很多问题,第一个问题,安卓的返回键BackAndroid问题,

我写了一个工具类,来搞定,其中用到了java原生代码与js交互;好吧,下面开始正式内容:

上代码:

// BackAndroidTool
// 功能: "安卓手机上的返回键"
// Created by 小广 on 2016-05-10 下午.
// Copyright © 2016年 All rights reserved.
/*
使用: 参考链接:http://reactnative.cn/post/480
 1.在首页/homepage页(只需要在全局都存在的页面调用一次监听即可)
 componentDidMount(){
 // 添加返回键监听
 BackAndroidTool.addBackAndroidListener(this.props.navigator);
 } 

 componentWillUnmount(){
 // 移除返回键监听
 BackAndroidTool.removeBackAndroidListener();
 }
 说明:BackAndroid在iOS平台下是一个空实现,
 所以理论上不做这个Platform.OS === 'android'判断也是安全的。 

 2. 某些类自定义返回键操作(即点击返回键弹出一个alert之类的操作)
 在所需类的初始化方法里调用BackAndroidTool.customHandleBack
 栗子:
 constructor(props) {
 super(props);
  BackAndroidTool.customHandleBack(this.props.navigator,() => {
   Alert.alert('提示','您还未保存记录,确定要返回么?',
      [{text:'取消',onPress:() => {}},
       {text:'确定',onPress:() => { this.props.navigator.pop(); }}
      ]);
     // 一定要 return true; 原因上面的参考链接里有
    return true;
  });
 } 

 3.某些页面需要禁用返回键
 在nav进行push的时候,设置属性ignoreBack为true 即可
 this.props.navigator.push({
 component: 所需要禁用的类,
 ignoreBack:true,
 }); 

*/ 

'use strict';
import React,{
 Platform,
 Navigator,
 BackAndroid,
 ToastAndroid,
 NativeModules,
} from 'react-native'; 

// 类
var NativeCommonTools = NativeModules.CommonTools; 

export default {
 // 监听返回键事件
 addBackAndroidListener(navigator) {
 if (Platform.OS === 'android') {
  BackAndroid.addEventListener('hardwareBackPress',() => {
   return this.onBackAndroid(navigator);
  });
 }
 }, 

 // 移除监听
 removeBackAndroidListener() {
 if (Platform.OS === 'android') {
  BackAndroid.removeEventListener('hardwareBackPress', () => {
  });
 }
 }, 

 // 判断是返回上一页还是退出程序
 onBackAndroid(navigator) {
 if (!navigator) return false;
 const routers = navigator.getCurrentRoutes();
 // 当前页面不为root页面时的处理
 if (routers.length > 1) {
  const top = routers[routers.length - 1];
  if (top.ignoreBack || top.component.ignoreBack) {
   // 路由或组件上决定这个界面忽略back键
   return true;
  }
  const handleBack = top.handleBack || top.component.handleBack;
  if (handleBack) {
   // 路由或组件上决定这个界面自行处理back键
   return handleBack();
  }
 // 默认行为: 退出当前界面。
  navigator.pop();
  return true;
  }
 // 当前页面为root页面时的处理
 if (this.lastBackPressed && (this.lastBackPressed + 2000 >= Date.now())) {
   //最近2秒内按过back键,可以退出应用。
   NativeCommonTools.onBackPressed();
   return true;
  }
  this.lastBackPressed = Date.now();
  ToastAndroid.show('再按一次退出应用',ToastAndroid.SHORT);
  return true;
 }, 

 // 自定义返回按钮事件
 customHandleBack(navigator, handleBack) {
 if (navigator) {
  let routes = navigator.getCurrentRoutes(); //nav是导航器对象
  let lastRoute = routes[routes.length - 1]; // 当前页面对应的route对象
  lastRoute.handleBack = handleBack;
 }
 }, 

} 

其中的java原生代码如下:

管理类:RCTCommonToolsPackage (ps:如是不明白,可以去这里 React Native学习:http://reactnative.cn/docs/0.25/native-modules-android.html#content);

package com.commonTools; 

import com.facebook.react.ReactPackage;
import com.facebook.react.bridge.JavaScriptModule;
import com.facebook.react.bridge.NativeModule;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.uimanager.ViewManager; 

import java.util.Arrays;
import java.util.Collections;
import java.util.List; 

public class RCTCommonToolsPackage implements ReactPackage {
 @Override
 public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
 return Arrays.<NativeModule>asList(new RCTCommonTools(reactContext));
 } 

 @Override
 public List<Class<? extends JavaScriptModule>> createJSModules() {
 return Collections.emptyList();
 } 

 @Override
 public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
 return Collections.emptyList();
 }
} 

自定义方法的类:RCTCommonTools

package com.commonTools; 

import android.content.Intent; 

import com.facebook.react.bridge.Callback;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReactContextBaseJavaModule;
import com.facebook.react.bridge.ReactMethod; 

import com.tcpaydls.BuildConfig; 

public class RCTCommonTools extends ReactContextBaseJavaModule { 

 public RCTCommonTools(ReactApplicationContext reactContext) {
 super(reactContext);
 } 

 @Override
 public String getName() {
 return "RCTCommonTools";
 } 

 /**
 * 此方法是为了解决返回键退出程序后,ToastAndroid不会消失的bug
 */
 @ReactMethod
 public void onBackPressed() {
 Intent setIntent = new Intent(Intent.ACTION_MAIN);
 setIntent.addCategory(Intent.CATEGORY_HOME);
 setIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
 getCurrentActivity().startActivity(setIntent); 

 }
} 

总结

以上就是这篇文章的全部内容了,本文还有许多不足,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • Android Rreact Native 常见错误总结

    Android Rreact Native 常见错误总结 1.invariant violation:expected a component class,got[object object] 创建自定义组件首字母要大写,否则会报错. 2.Module 0 is not a registered callable module. 将gradle升级成最新版本(cd Android 进入android目录执行:sudo ./gradlew clean) 或者通过android studio工具升级

  • 详解React Native监听Android回退按键与程序化退出应用

    详解React Native监听Android回退按键与程序化退出应用 前言 我们知道Android回退按键,会控制页面返回, 并且退出应用并非真正意义退出,仍在后台运行,所以在某些场景下需要监控android回退按键,那么在React Native中应该如何应用呢?我们具体来看看. BackAndroid 此模块用于监听硬件的back键操作. 看下具体代码: BackAndroid.addEventListener('hardwareBackPress', function() { if (!

  • React Native中Android物理back键按两次返回键即退出应用

    前言 本文主要给大家介绍了关于React Native中Android物理back键按两次返回键就会退出应用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 话不多说,直接上图: 测试代码 第16~22行 设置事件监听以及移除事件监听. componentWillMount(){ BackAndroid.addEventListener('hardwareBackPress', this.onBackAndroid); } componentWillUnmount()

  • React Native学习之Android的返回键BackAndroid详解

    前言 最近在学习使用 React Native开发,iOS搞完,开始适配安卓,由于木有接触过安卓,所以碰到了很多问题,第一个问题,安卓的返回键BackAndroid问题, 我写了一个工具类,来搞定,其中用到了java原生代码与js交互;好吧,下面开始正式内容: 上代码: // BackAndroidTool // 功能: "安卓手机上的返回键" // Created by 小广 on 2016-05-10 下午. // Copyright © 2016年 All rights rese

  • React Native 混合开发多入口加载方式详解

    在已有app混合开发时,可能会有多个rn界面入口的需求,这个时候我们可以使用RCTRootView中的moduleName或initialProperties来实现加载包中的不同页面. 目前使用RCTRootView有两种方式: 使用initialProperties传入props属性,在React中读取属性,通过逻辑来渲染不同的Component 配置moduleName,然后AppRegistry.registerComponent注册同名的页面入口 这里贴出使用0.60.5版本中ios项目

  • Android 拦截返回键事件的实例详解

    Android 拦截返回键事件的实例详解 KeyEvent类 Android.View.KeyEvent类中定义了一系列的常量和方法,用来描述Android中的 按键事件和返回键有关的常量和方法有. KeyEvent.KEYCODE_BACK: 表示key类型为返回键 KeyEvent.ACTION_DOWN:表示事件为按下key,如果一直按住不放,则会不停产生此事件. KeyEvent.ACTION_UP:表示事件为为放开key,一次点击key过程只会调用一次. public final in

  • Android 双击返回键退出程序的方法总结

    Android 双击返回键退出程序的方法总结 下面先说说LZ思路,具体如下: 1. 第一种就是根据用户点击俩次的时间间隔去判断是否退出程序; 2. 第二种就是使用Android中计时器(Timer),其实这俩种都差不多. 思路是有了,,,接下来要怎么开搞呢???用户点击肯定会触发相应的事件,,,我们先来看下面俩个事件的作用... Activity.onKeyDown(); 当某个键被按下时会触发,但不会被任何的该Activity内的任何view处理. 默认按下KEYCODE_BACK键后会回到上

  • Android实现返回键功能

    记录用户点击的操作历史,使用栈数据结构,频繁的操作栈顶(添加,获取,删除),使用LinkedList 捕获用户的返回键操作,响应返回键,返回上一个界面 MainActivity.java /** * 返回键处理 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if(keyCode==KeyEvent.KEYCODE_BACK){ boolean result=MiddleManager.getInstanc

  • Android双击返回键退出程序的实现方法

    本文实例讲述了Android双击返回键退出程序的实现方法,是Android程序开发中一个非常实用的功能,分享给大家供大家参考之用.具体方法如下: 一.实现思路: 用户按下返回键时设定一个定时器来监控是否2秒内实现了退出,如果用户没有接着按返回键,则清除第一次按返回键的效果,使程序还原到第一次按下返回键之前的状态.定时器是每次用户按下返回键才去创建. 二.功能代码: /** * 菜单.返回键响应 */ @Override public boolean onKeyDown(int keyCode,

  • Android开发返回键明暗点击效果的实例代码

    1:在很多APP里点击返回键,都可以看到返回键由亮变为暗 2:实现方法也是很简单的 (1)新建一个页面 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="65dp" android:background="#258a

  • React Native 中处理 Android 手机吞字的解决方案

    目录 复现问题 解决问题 示例 React Native App 在部分型号的 Android 手机上,可能会发生文字显示不全的问题. 官方也有一个 相关的 Issue ,并提供了如下的解决方案: const defaultFontFamily = { ...Platform.select({ android: { fontFamily: "" }, }), } const oldRender = Text.render Text.render = function (...args)

  • Android的搜索框架实例详解

    基础知识 Android的搜索框架将代您管理的搜索对话框,您不需要自己去开发一个搜索框,不需要担心要把搜索框放什么位置,也不需要担心搜索框影响您当前的界面.所有的这些工作都由SearchManager类来为您处理(以下简称"搜索管理器"),它管理的Android搜索对话框的整个生命周期,并执行您的应用程序将发送的搜索请求,返回相应的搜索关键字. 当用户执行一个搜索,搜索管理器将使用一个专门的Intent把搜索查询的关键字传给您在配置文件中配置的处理搜索结果的Activity.从本质上讲

随机推荐