這篇文章主要講解了“ionic怎么監(jiān)聽android返回鍵實(shí)現(xiàn)再按一次退出功能”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“ionic怎么監(jiān)聽android返回鍵實(shí)現(xiàn)再按一次退出功能”吧!
成都創(chuàng)新互聯(lián)公司提供高防服務(wù)器、云服務(wù)器、香港服務(wù)器、德陽機(jī)房托管等在android平臺上的app,在主頁面時經(jīng)常會遇到“再按一次退出app”的功能,避免只按一下返回鍵就退出app提升體驗(yàn)優(yōu)化。
1、這個功能需要我們用到ionic提供的registerBackButtonAction方法(注冊硬件后退按鈕動作)
registerBackButtonAction(callback, priority, [actionId])
參數(shù) 類型 說明
callback function 當(dāng)點(diǎn)擊返回按鈕時觸發(fā),如果該監(jiān)視器具有高的優(yōu)先級
priority number 僅高優(yōu)先級的會執(zhí)行
actionId(可空) * 該id指定這個動作 默認(rèn): 一個隨機(jī)且的id
后退按鈕的優(yōu)先執(zhí)行順序:
返回到上一個視圖 = 100
關(guān)閉側(cè)邊菜單 = 150
關(guān)閉模版modal = 200
關(guān)閉上拉菜單action sheet = 300
關(guān)閉對話框popup = 400
關(guān)閉加載框loading = 500
注意:返回: function一個被觸發(fā)的函數(shù),將會注銷 backButtonAction。
如果我們不想注冊返回按鈕影響所有頁面,就要將返回函數(shù)再調(diào)用。
例如:如果一個上拉菜單已經(jīng)顯示,后退按鈕應(yīng)該關(guān)閉上拉菜單,而不是返回一個頁面視圖或關(guān)閉一個打開的模型。
所以我們要實(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)用戶在主頁面, 按返回鍵時,給予提示,如果在2s內(nèi)再次出發(fā)返回鍵,就退出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); } // 判斷當(dāng)前路由,是否是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 環(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."); } }); }]);
感謝各位的閱讀,以上就是“ionic怎么監(jiān)聽android返回鍵實(shí)現(xiàn)再按一次退出功能”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對ionic怎么監(jiān)聽android返回鍵實(shí)現(xiàn)再按一次退出功能這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
分享標(biāo)題:ionic怎么監(jiān)聽android返回鍵實(shí)現(xiàn)再按一次退出功能-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://www.rwnh.cn/article48/dpesep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、移動網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)公司、企業(yè)網(wǎng)站制作、標(biāo)簽優(yōu)化、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容