ionic3学习之Android返回键的处理

provider 简介

了解 ionic3 的 provider
provider 是 ionic 自己定义的一个概念,类似于我们在 angular上面的 service。两者有部分的相同点以及不同点。
对比:

  • 不同点
技术 使用的命令 文件名 路径 类的名字
ionic ionic g provider config config.ts 位于providers/config下 ConfigProvider
angular ng g service config config.service.ts 文件所建文件夹的目录下 ConfigService
  • 相同点
    按照 angular 的 service 来理解,因为 ionic 是基于 angular 来开发的。基于 angular 的概念理解就最直观。 都可以使用 @Injectable()来标识,可以用来依赖注入。
    详细的可以看下 angular 的 service 文章
    angular的依赖注入
    Angular4学习笔记之依赖注入

创建返回按键的处理服务

我的服务是改过了几次路径,最终的路径在 src/providers/utils/ 下
back-button-service.ts

import { Injectable } from '@angular/core';import { Platform, ToastController, App, NavController, Tabs } from 'ionic-angular';@Injectable()export class BackButtonServiceProvider {  //控制硬件返回按钮是否触发,默认false  backButtonPressed: boolean = false;  //构造函数 依赖注入  constructor(public platform: Platform,              public appCtrl: App,              public toastCtrl: ToastController) { }  //注册方法  registerBackButtonAction(tabRef: Tabs): void {    //registerBackButtonAction是系统自带的方法    this.platform.registerBackButtonAction(() => {      //获取NavController      let activeNav: NavController = this.appCtrl.getActiveNav();      // 有博主说上面的方法在新的版本中被移除,但是我在测试的时候还可以继续使用,下面这段代码是新的使用方式,我也贴出来。         // let activeNav: NavController = this.appCtrl.getActiveNavs()[0];      //如果可以返回上一页,则执行pop      if (activeNav.canGoBack()) {        activeNav.pop();      } else {        if (tabRef == null || tabRef._selectHistory[tabRef._selectHistory.length - 1] === tabRef.getByIndex(0).id) {          //执行退出          this.showExit();        } else {          //选择首页第一个的标签          tabRef.select(0);        }      }    });  }  //退出应用方法  private showExit(): void {    //如果为true,退出    if (this.backButtonPressed) {      this.platform.exitApp();    } else {      //第一次按,弹出Toast      this.toastCtrl.create({        message: '再按一次退出应用',        duration: 2000,        position: 'top'      }).present();      //标记为true      this.backButtonPressed = true;      //两秒后标记为false,如果退出的话,就不会执行了      setTimeout(() => this.backButtonPressed = false, 2000);    }  }}

注入返回处理逻辑的服务

第一步:修改 tab.html

// 增加 #myTabs 属性<ion-tabs #myTabs></ion-tabs>

第二步,修改 tab.ts

// 引入需要使用到的模块import {Component, ViewChild} from '@angular/core';import {NavParams, Platform, Tabs} from 'ionic-angular';import {BackButtonServiceProvider} from "../../providers/utils/back-button-service";
// 在 class 中增加代码@ViewChild('myTabs') tabRef: Tabs;constructor(public navParams: NavParams,              public platform: Platform,              public backButtonService: BackButtonServiceProvider) {    platform.ready().then(() => {      this.backButtonService.registerBackButtonAction(this.tabRef);    });  }

到此我们就修改完成了。需要在模拟器上面或者 android手机上面调试查看。

更多相关文章

  1. android 绕过R文件,通过代码获取styleable的属性
  2. Android开发实践 ContentProvider和ContentResolver
  3. android的popupwindow点击返回按钮关闭
  4. 调用Android原生裁剪方式裁剪图片并保存
  5. Android仿考拉全局滑动返回及联动效果的实现方法
  6. Android填坑之旅(第十六篇)Android优雅解决App应用异常退出并收集
  7. Android(安卓)Annotations 学习之路(一)环境配置以及@EActivity在
  8. [置顶] android实现向右滑动返回功能
  9. android带返回按钮的自定义标题栏布局文件详解

随机推荐

  1. 多渠道打包正式签名APK
  2. Android Crash实例分析与解决
  3. Android 手势锁的实现 让自己的应用更加
  4. 《Pro Android Graphics》读书笔记之第三
  5. android播放本地工程里的音乐和视频的方
  6. RK3288 android7.1 蓝牙MAC地址获取
  7. Android中判断应用是否第一次打开
  8. Android Native C 之 Helloworld的四种编
  9. android ListView 刷新数据,加载时遇到的
  10. android recyclerView 设置item间的间距