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

作者:开发仔XG 时间:2023-04-19 14:15:28 

前言

最近在学习使用 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);

}
}

来源:http://blog.csdn.net/syg90178aw/article/details/51387455

标签:reactnative,android,返回键backandroid
0
投稿

猜你喜欢

  • SpringBoot获取yml和properties配置文件的内容

    2022-12-02 18:26:08
  • Java关键字synchronized原理与锁的状态详解

    2021-11-16 05:30:29
  • Android存储字符串数据到txt文件

    2021-11-05 21:55:16
  • C#设计模式之Builder生成器模式解决带老婆配置电脑问题实例

    2021-07-09 03:22:59
  • 开源自研内存分析利器Android Bitmap Monitor图片定位详解

    2023-02-04 13:45:36
  • Hook实现Android 微信、陌陌 、探探位置模拟(附源码下载)

    2022-11-14 14:44:43
  • C#实现希尔排序

    2023-11-02 08:15:04
  • idea mybatis配置log4j打印sql语句的示例

    2023-11-25 10:32:39
  • Java实现自动压缩文件并加密的方法示例

    2023-05-08 03:33:18
  • 详解C#实现MD5加密的示例代码

    2023-11-28 21:01:54
  • C#实现FTP传送文件的示例

    2022-06-24 01:15:20
  • 关于C#中的Invoke示例详解

    2023-06-20 10:17:14
  • Reactor 多任务并发执行且结果按顺序返回第一个

    2021-08-15 03:32:46
  • Spring Security认证机制源码层探究

    2022-07-27 19:05:26
  • Android手机闹钟服务AlarmManagerk开发案例

    2023-05-21 14:15:28
  • Java实现角色扮演游戏的示例代码

    2023-03-31 19:41:45
  • java注解结合aspectj AOP进行日志打印的操作

    2023-10-23 14:02:53
  • 详解ThreadLocal为什么会内存溢出原理

    2023-11-09 18:45:26
  • java实现图书馆管理系统

    2023-12-10 15:50:29
  • Android Mms之:短信发送流程(图文详解)

    2022-07-27 02:10:21
  • asp之家 软件编程 m.aspxhome.com