android按钮返回软件,Ionic系列——android双击退出应用和物理返回按钮隐藏键盘的实现...

该博客围绕Android手机物理返回键功能展开。需求是自定义返回键单击事件,控制返回时隐藏键盘,实现首页面和登录页双击退出应用。介绍了添加相关插件的准备工作,还给出了代码实现,包括引入依赖及具体的返回按钮控制逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、需求描述

因为要控制在返回上一页面的时候,如果有键盘,需要先隐藏键盘,所以需要自定义android手机的物理返回键单击事件,自己定义返回按钮的优先级操作,然后实现在首页面和登录页双击退出应用的操作。

2、准备

添加插件$cordovaToast,$cordovaKeyboard

cordova plugin add https://github.com/driftyco/ionic-plugins-keyboard.git

cordova plugin add https://github.com/EddyVerbruggen/Toast-PhoneGap-Plugin.git

3、代码实现

引入$cordovaToast,$cordovaKeyboard的依赖。

angular.module('starter', ['ionic', 'route', 'config', 'global', 'commonJs', 'ngCordova'])

.run(['$ionicPlatform', '$rootScope', '$location', '$timeout', '$ionicHistory', 'CommonJs', '$cordovaToast','$cordovaKeyboard', function ($ionicPlatform, $rootScope, $location, $timeout, $ionicHistory,CommonJs,$cordovaToast,$cordovaKeyboard) {

$ionicPlatform.ready(function () {

// Hide the accessory bar by default (remove this to show the accessory bar above the keyboard

if (window.cordova && window.cordova.plugins && window.cordova.plugins.Keyboard) {

cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);

}

if (window.StatusBar) {

// org.apache.cordova.statusbar required

StatusBar.styleLightContent();

}

});

//物理返回按钮控制&双击退出应用

$ionicPlatform.registerBackButtonAction(function (e) {

//判断处于哪个页面时双击退出

if ($location.path() == '/tab/todoList' || $location.path() == '/tab/doneList' || $location.path() == '/tab/account'|| $location.path() == '/login') {

if ($rootScope.backButtonPressedOnceToExit) {

ionic.Platform.exitApp();

} else {

$rootScope.backButtonPressedOnceToExit = true;

$cordovaToast.showShortBottom('再按一次退出系统');

setTimeout(function () {

$rootScope.backButtonPressedOnceToExit = false;

}, 2000);

}

}else if ($ionicHistory.backView()) {

if ($cordovaKeyboard.isVisible()) {

$cordovaKeyboard.close();

} else {

$ionicHistory.goBack();

}

}

else {

$rootScope.backButtonPressedOnceToExit = true;

$cordovaToast.showShortBottom('再按一次退出系统');

setTimeout(function () {

$rootScope.backButtonPressedOnceToExit = false;

}, 2000);

}

e.preventDefault();

return false;

}, 101);

}]);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值