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方法(注冊硬件后退按鈕動(dòng)作)
- registerBackButtonAction(callback, priority, [actionId])
- 參數(shù) 類型 說明
- callback function 當(dāng)點(diǎn)擊返回按鈕時(shí)觸發(fā),如果該監(jiān)視器具有最高的優(yōu)先級
- priority number 僅最高優(yōu)先級的會(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)閉對話框popup = 400
關(guān)閉加載框loading = 500
注意:返回: function一個(gè)被觸發(fā)的函數(shù),將會(huì)注銷 backButtonAction。
如果我們不想注冊返回按鈕影響所有頁面,就要將返回函數(shù)再調(diào)用。
例如:如果一個(gè)上拉菜單已經(jīng)顯示,后退按鈕應(yīng)該關(guān)閉上拉菜單,而不是返回一個(gè)頁面視圖或關(guān)閉一個(gè)打開的模型。
所以我們要實(shí)現(xiàn)“再按一次退出app”的功能,可以將優(yōu)先級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); } // 注冊返回事件 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."); } }); }]);
這樣我們就很簡單實(shí)現(xiàn)了一個(gè)"再按一次退出app的功能"
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android自定義View設(shè)定到FrameLayout布局中實(shí)現(xiàn)多組件顯示的方法 分享
Android自定義View設(shè)定到FrameLayout布局中實(shí)現(xiàn)多組件顯示的方法 分享,需要的朋友可以參考一下2013-05-05Android自定義控件LinearLayout實(shí)例講解
這篇文章主要為大家詳細(xì)介紹了Android自定義控件LinearLayout實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05Android 仿摩拜單車共享單車進(jìn)度條實(shí)現(xiàn)StepView效果
這篇文章主要介紹了android 仿摩拜單車共享單車進(jìn)度條實(shí)現(xiàn)StepView效果的實(shí)例,通過定義五個(gè)狀態(tài),分別為:為完成、正在進(jìn)行、已完成、終點(diǎn)完成、終點(diǎn)未完成。具體實(shí)現(xiàn)代碼,大家參考下2017-03-03Android10填坑適配指南(實(shí)際經(jīng)驗(yàn)代碼)
這篇文章主要介紹了Android10填坑適配指南(實(shí)際經(jīng)驗(yàn)代碼),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11Android開發(fā)高級組件之自動(dòng)完成文本框(AutoCompleteTextView)用法示例【附源碼下載】
這篇文章主要介紹了Android開發(fā)高級組件之自動(dòng)完成文本框(AutoCompleteTextView)用法,簡單描述了自動(dòng)完成文本框的功能并結(jié)合實(shí)例形式分析了Android實(shí)現(xiàn)自動(dòng)完成文本框功能的具體步驟與相關(guān)操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下2018-01-01Android使用httpPost向服務(wù)器發(fā)送請求的方法
這篇文章主要介紹了Android使用httpPost向服務(wù)器發(fā)送請求的方法,實(shí)例分析了Android針對HttpPost類的操作技巧,需要的朋友可以參考下2015-12-12