ionic監(jiān)聽android返回鍵實(shí)現(xiàn)“再按一次退出”功能
在android平臺(tái)上的app,在主頁面時(shí)經(jīng)常會(huì)遇到“再按一次退出app”的功能,避免只按一下返回鍵就退出app提升體驗(yàn)優(yōu)化。
1、這個(gè)功能需要我們用到ionic提供的registerBackButtonAction方法(注冊(cè)硬件后退按鈕動(dòng)作)
- registerBackButtonAction(callback, priority, [actionId])
- 參數(shù) 類型 說明
- callback function 當(dāng)點(diǎn)擊返回按鈕時(shí)觸發(fā),如果該監(jiān)視器具有最高的優(yōu)先級(jí)
- priority number 僅最高優(yōu)先級(jí)的會(huì)執(zhí)行
- actionId(可空) * 該id指定這個(gè)動(dòng)作 默認(rèn): 一個(gè)隨機(jī)且唯一的id
后退按鈕的優(yōu)先執(zhí)行順序:
返回到上一個(gè)視圖 = 100
關(guān)閉側(cè)邊菜單 = 150
關(guān)閉模版modal = 200
關(guān)閉上拉菜單action sheet = 300
關(guān)閉對(duì)話框popup = 400
關(guān)閉加載框loading = 500
注意:返回: function一個(gè)被觸發(fā)的函數(shù),將會(huì)注銷 backButtonAction。
如果我們不想注冊(cè)返回按鈕影響所有頁面,就要將返回函數(shù)再調(diào)用。
例如:如果一個(gè)上拉菜單已經(jīng)顯示,后退按鈕應(yīng)該關(guān)閉上拉菜單,而不是返回一個(gè)頁面視圖或關(guān)閉一個(gè)打開的模型。
所以我們要實(shí)現(xiàn)“再按一次退出app”的功能,可以將優(yōu)先級(jí)priority設(shè)為101
2、代碼實(shí)現(xiàn)
在js中
angular.module("app").run(["$rootScope", "$ionicPlatform",
"$location", "$ionicHistory",
function ($rootScope, $ionicPlatform, $location, $ionicHistory) {
"use strict";
// 當(dāng)用戶在主頁面, 按返回鍵時(shí),給予提示,如果在2s內(nèi)再次出發(fā)返回鍵,就退出app
function showTipMsg() {
window.plugins.toast.showShortCenter("在按一次退出app"); // toast是cordova的一個(gè)插件cordova-plugin-x-toast,也可以用ionic的彈窗來代替
$rootScope.exitApp = true;
const delay = 2000;
setTimeout(() => {
$rootScope.exitApp = false;
}, delay);
}
// 判斷當(dāng)前路由,是否是project, mission,mine, message這幾個(gè)主頁面
function isExitPage() {
let path = $location.path(),
state = _.last(path.split("/")),
ary = ["project", "mission", "mine", "", "message"];
return _.includes(ary, state);
}
// 注冊(cè)返回事件
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 環(huán)境已經(jīng)準(zhǔn)備完畢
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.");
}
});
}]);
這樣我們就很簡(jiǎn)單實(shí)現(xiàn)了一個(gè)"再按一次退出app的功能"
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android性能優(yōu)化之線程監(jiān)控與線程統(tǒng)一詳解
這篇文章主要為大家介紹了Android性能優(yōu)化之線程監(jiān)控與線程統(tǒng)一詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Android之RecyclerView實(shí)現(xiàn)時(shí)光軸效果示例
本篇文章主要介紹了Android之RecyclerView實(shí)現(xiàn)時(shí)光軸效果,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
Android SDK Manager解決更新時(shí)的問題 :Failed to fetch URL...
本文主要介紹解決安裝使用SDK Manager更新時(shí)的問題:Failed to fetch URL...,這里提供了詳細(xì)的資料及解決問題辦法,有需要的小伙伴可以參考下2016-09-09
Android自定義View Material Design理念詳解
這篇文章主要為大家介紹了Android自定義View Material Design理念詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
SwipeRefreshLayout+RecyclerView實(shí)現(xiàn)上拉刷新和下拉刷新功能
這篇文章主要介紹了SwipeRefreshLayout+RecyclerView實(shí)現(xiàn)上拉刷新和下拉刷新功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
Android實(shí)戰(zhàn)RecyclerView頭部尾部添加方法示例
本篇文章主要介紹了Android實(shí)戰(zhàn)RecyclerView頭部尾部添加方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11
android初學(xué)者必須掌握的Activity狀態(tài)的四大知識(shí)點(diǎn)(必讀)
本篇文章主要介紹了android activity的四種狀態(tài),詳細(xì)的介紹了四種狀態(tài),包括Running狀態(tài)、Paused狀態(tài)、Stopped狀態(tài)、Killed狀態(tài),有興趣的可以了解一下。2016-11-11
Android系統(tǒng)添加自定義鼠標(biāo)樣式通過按鍵切換實(shí)例詳解
在本篇文章里小編給大家整理的是關(guān)于Android系統(tǒng)添加自定義鼠標(biāo)樣式通過按鍵切換實(shí)例詳解內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2019-11-11

