android 监听程序退出,ionic监听android返回键实现“再按一次退出”功能

在android平台上的app,在主页面时经常会遇到“再按一次退出app”的功能,避免只按一下返回键就退出app提升体验优化。

registerBackButtonAction(callback, priority, [actionId])

参数 类型 说明

callback function 当点击返回按钮时触发,如果该监视器具有最高的优先级

priority number 仅最高优先级的会执行

actionId(可空) * 该id指定这个动作 默认: 一个随机且唯一的id

后退按钮的优先执行顺序:

返回到上一个视图 = 100

关闭侧边菜单 = 150

关闭模版modal = 200

关闭上拉菜单action sheet = 300

关闭对话框popup = 400

关闭加载框loading = 500

注意:返回: function一个被触发的函数,将会注销 backButtonAction。

如果我们不想注册返回按钮影响所有页面,就要将返回函数再调用。

例如:如果一个上拉菜单已经显示,后退按钮应该关闭上拉菜单,而不是返回一个页面视图或关闭一个打开的模型。

所以我们要实现“再按一次退出app”的功能,可以将优先级priority设为101

2、代码实现

在js中

angular.module("app").run(["$rootScope", "$ionicPlatform",

"$location", "$ionicHistory",

function ($rootScope, $ionicPlatform, $location, $ionicHistory) {

"use strict";

// 当用户在主页面, 按返回键时,给予提示,如果在2s内再次出发返回键,就退出app

function showTipMsg() {

window.plugins.toast.showShortCenter("在按一次退出app"); // toast是cordova的一个插件cordova-plugin-x-toast,也可以用ionic的弹窗来代替

$rootScope.exitApp = true;

const delay = 2000;

setTimeout(() => {

$rootScope.exitApp = false;

}, delay);

}

// 判断当前路由,是否是project, mission,mine, message这几个主页面

function isExitPage() {

let path = $location.path(),

state = _.last(path.split("/")),

ary = ["project", "mission", "mine", "", "message"];

return _.includes(ary, state);

}

// 注册返回事件

function registerBackButton(event) {

event.preventDefault();

$cordovaKeyboard.isVisible() && $cordovaKeyboard.close();

if (isExitPage()) {

$rootScope.exitApp && ionic.Platform.exitApp();

!$rootScope.exitApp && showTipMsg();

} else {

$ionicHistory.goBack();

}

return false;

}

// ionic 环境已经准备完毕

ionic.Platform.ready(() => {

try {

const priority = 101;

$ionicPlatform.is("Android") && $ionicPlatform.registerBackButtonAction(registerBackButton, priority);

} catch (e) {

console.warn("Application is running in browser causes inspection failed.");

}

});

}]);

这样我们就很简单实现了一个"再按一次退出app的功能"

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值