在 Android 和 Window 平台下,有时候我们需要监听返回按键的事件来进行相应的操作,也就是自定义返回按键事件。下面根据一个例子来讲解如何在 ionic 中自定义返回按键事件。

功能需求

首先看下要通过自定义返回按键事件来实现的需求(均在点击返回键操作之后):

  • 如果键盘打开,则隐藏键盘;
  • 如果显示 ionic 的 Loading 组件(在请求数据的时候),则隐藏 Loading 组件;
  • 如果当前页面是子页面,则返回上个页面;如果是根页面,则提示用户是否退出应用。

具体实现

首先说明下,本示例的 ionic 应用的结构是 tabs 结构。

  1. tabs.html 中的 ion-tabs 定义别名,如 mainTabs
<ion-tabs #mainTabs selectedIndex="1">
<ion-tab [root]="tab1Root" tabTitle="页面1"></ion-tab>
<ion-tab [root]="tab2Root" tabTitle="页面2"></ion-tab>
</ion-tabs>

ion-tabs 定义别名的目的是方便通过代码找到 ion-tabs 的实例。

  1. app.component.ts 中进行实现代码编写(实现细节在注释中):
import { Component, ViewChild } from '@angular/core';
import { Nav, Platform, Keyboard, IonicApp, NavController, Tabs, ToastController, Toast } from 'ionic-angular'; @Component({
templateUrl: 'app.html'
})
export class AppComponent {
@ViewChild(Nav) nav: Nav; // ion-nav 引用
backButtonPressed: boolean = false; // 用于判断返回键是否触发 constructor(public platform: Platform,
public ionicApp: IonicApp,
public toastCtrl: ToastController,
public keyboard: Keyboard) { // 等待平台加载完成之后注册返回按键事件
this.platform.ready().then(() => {
this.registerBackButtonAction(); // 注册返回按键事件
});
} /**
* 注册返回按键事件
*/
registerBackButtonAction() { // 使用 registerBackButtonAction 方法进行自定义事件处理程序
this.platform.registerBackButtonAction(() => { // 如果键盘开启则隐藏键盘。实现要点:使用 ionic-plugin-keyboard 插件进行键盘的控制
if (this.keyboard.isOpen()) {
this.keyboard.close();
return;
} // 隐藏加载动画。实现要点:通过 this.ionicApp._loadingPortal 获取到代表 Loading 的 OverlayPortal,然后获取当前被激活的 ViewController
const activePortal: any = this.ionicApp._loadingPortal.getActive();
if (activePortal) { // 如果有被激活的 ViewController 则将其隐藏。
activePortal.dismiss();
activePortal.onDidDismiss();
return;
} // 根据当前导航进行不同的处理( mainTabs 对象是在 TabsPage 定义的 ion-tabs )
// 通过 this.nav.getActive().instance.mainTabs 获取到别名为 mainTabs 的 ion-tabs
const mainTabs: Tabs = this.nav.getActive().instance.mainTabs;
if (mainTabs) { // 获取到当前被选中的 ion-tab
const mainNav: NavController = mainTabs.getSelected(); // 如果 ion-tab 能返回则返回上一个页面,不能就直接退出应用
mainNav.canGoBack() ? mainNav.pop() : this.showExit();
} else { // 如果 ion-nav 能返回则返回上一个页面,不能就直接退出应用
this.nav.canGoBack() ? this.nav.pop() : this.showExit();
}
return;
}, 1);
} /**
* 双击退出提示框
*/
showExit() {
if (this.backButtonPressed) { // 当触发标志为 true 时,即2秒内双击返回按键则退出APP
this.platform.exitApp();
} else {
const currentToast: Toast = this.toastCtrl.create({
message: '再按一次退出应用',
duration: 2000,
position: 'top'
});
currentToast.present().then(() => {
this.backButtonPressed = true; // 2秒内没有再次点击返回则将触发标志标记为false
const id: any = setTimeout(() => {
clearTimeout(id);
this.backButtonPressed = false;
}, 2000);
});
}
}
}

Ionic实现自定义返回按键事件的更多相关文章

  1. vue JS实现监听浏览器返回按键事件

    // 这个是监听浏览器回退键的returnButton () { let vm = this; $(document).ready(function () { if (window.history & ...

  2. 移动端默认返回按键,使用h5+修改默认事件

    hbuilder的h5+提供开发webapp的诸多便利,很多手机自带back虚拟按键,如果不修改其默认事件,点一下app就退出了,所以我这里提供一种修改这个按键默认事件事件的代码. 首先你要用hbui ...

  3. Android按键事件传递流程(二)

    5    应用层如何从Framework层接收按键事件 由3.2和4.5.4节可知,当InputDispatcher通过服务端管道向socket文件描述符发送消息后,epoll机制监听到了I/O事件, ...

  4. Android Tv 中的按键事件 KeyEvent 分发处理流程

    这次打算来梳理一下 Android Tv 中的按键点击事件 KeyEvent 的分发处理流程.一谈到点击事件机制,网上资料已经非常齐全了,像什么分发.拦截.处理三大流程啊:或者 dispatchTou ...

  5. VBA中自定义类和事件的(伪)注册

    想了解一下VBA中自定义类和事件,以及注册事件处理程序的方法. 折腾了大半天,觉得这样的方式实在称不上“注册”,所以加一个“伪”字.纯粹是瞎试,原理也还没有摸透.先留着,有时间再接着摸. 做以下尝试: ...

  6. 【百度地图API】如何给自定义覆盖物添加事件

    原文:[百度地图API]如何给自定义覆盖物添加事件 摘要: 给marker.lable.circle等Overlay添加事件很简单,直接addEventListener即可.那么,自定义覆盖物的事件应 ...

  7. 转载 iOS拦截导航栏返回按钮事件的正确方式

    原文链接:http://www.jianshu.com/p/25fd027916fa 当我们使用了系统的导航栏时,默认点击返回按钮是 pop 回上一个界面.但是在有时候,我们需要在点击导航栏的返回按钮 ...

  8. input事件--->按键事件的基本实现

    本程序基于TINY4412开发板,程序已经验证过,完全正确: 那么,如何来写这样的一个驱动程序呢? 1.分配一个input_dev结构体 2.设置 3.注册 4.硬件相关的代码,比如中断,定时器,休眠 ...

  9. 安卓Tv开发(二)移动智能电视之焦点控制(按键事件)

    原文:http://blog.csdn.net/sk719887916/article/details/44781475 skay 前言:移动智能设备的发展,推动了安卓另一个领域,包括智能电视和智能家 ...

随机推荐

  1. NOIP Mayan游戏 - 搜索

    Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个7行5列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游戏通关是指在规定的步数内消除所有 ...

  2. Linux必备知识

    一.Linux命令行常用快捷键 在企业工作中,管理Linux时—般不会直接采用键盘.显示器登录系统,而是会通过网络在远程进行管理,因此,需要通过远程连接具连接到Linux系统中.目前最常用的Linux ...

  3. POJ 1222 EXTENDED LIGHTS OUT(高斯消元)题解

    题意:5*6的格子,你翻一个地方,那么这个地方和上下左右的格子都会翻面,要求把所有为1的格子翻成0,输出一个5*6的矩阵,把要翻的赋值1,不翻的0,每个格子只翻1次 思路:poj 1222 高斯消元详 ...

  4. yum第三方安装-软件包没签名及更新错误

    yum安装时 后面加 --nogpgcheck 阿里云源文件:http://mirrors.aliyun.com/repo/Centos-7.repo epel repo源:http://mirror ...

  5. Planar Shadow

    Unity上平面阴影的计算与实现 //如何求顶点投影到平面上的点(阴影点) //当平面上取不相等的任意两个点组成一个向量,与平面的法线总是垂直的,向量垂直点乘为0,因此可以通过一个点和一个法线来定义, ...

  6. HDU 1686 Oulippo

    http://acm.hdu.edu.cn/showproblem.php?pid=1686 题意:给定一个文本串和给定一个模式串,求文本串中有几个模式串. 思路:直接套用KMP模板. #includ ...

  7. 【Django】【四】测试

    [Testing in Django] 通过参数可控制Django项目不同级别的测试. 1. 运行sign应用下所有的测试用例: \\guest\python manage.py test sign ...

  8. codevs 1191 数轴染色 区间更新加延迟标记

    题目描述 Description 在一条数轴上有N个点,分别是1-N.一开始所有的点都被染成黑色.接着我们进行M次操作,第i次操作将[Li,Ri]这些点染成白色.请输出每个操作执行后剩余黑色点的个数. ...

  9. Unix网络编程_卷1卷2

    1. UNIX 网络编程(第2版)第1卷:套接口API和X/Open 传输接口API PDFhttp://www.linuxidc.com/Linux/2014-04/100155.htm UNIX网 ...

  10. es5,es6,typescript,nodejs

    es5新特性 讲到js必讲的几个概念,作用域,闭包,IIFE自执行函数 es5主要是对Object,Array,Function做了扩展,还有josn工具 es6新特性 增加了新的数据类型 WeakM ...