ionic App問題總結(jié)系列之ionic點擊系統(tǒng)返回鍵退出App
在安卓下,如果不處理系統(tǒng)返回鍵的事件,那么每次點擊返回鍵,將頁面將返回到上一個路由,這種邏輯不符合app的路由邏輯。正確的應(yīng)該是:當(dāng)頁面到了各個導(dǎo)航頁的首頁時,此時再按返回鍵應(yīng)該提示是否退出app,用戶點擊確認(rèn)后退出app。
在run()方法中添加下面的方法
$ionicPlatform.registerBackButtonAction(function (e){ //阻止默認(rèn)的行為 e.preventDefault(); // 退出提示框 function showConfirm() { var servicePopup = $ionicPopup.show({ title: '提示', subTitle: '你確定要退出應(yīng)用嗎?', scope: $rootScope, buttons: [ { text: '取消', type: 'button-clear button-assertive', onTap: function () { return 'cancel'; } }, { text: '確認(rèn)', type: 'button-clear button-assertive border-left', onTap: function (e) { return 'active'; } }, ] }); servicePopup.then(function (res) { if (res == 'active') { // 退出app ionic.Platform.exitApp(); } }); } // 判斷當(dāng)前路由是否為各個導(dǎo)航欄的首頁,是的話則顯示提示框 if ($location.path() == '/index' || $location.path() == '/product' || $location.path() == '/account' || $location.path() == '/more') { showConfirm(); } else if ($ionicHistory.backView()) { $ionicHistory.goBack(); } else { showConfirm(); } return false; }, 101); //101優(yōu)先級常用于覆蓋‘返回上一個頁面'的默認(rèn)行為
$ionicPlatform.registerBackButtonAction()
該方法是用來注冊系統(tǒng)返回鍵事件。每次點擊只會執(zhí)行最高優(yōu)先級的那個行為。比如當(dāng)頁面存在一個modal框的時候,此時點擊系統(tǒng)返回鍵則是關(guān)閉modal框,而不是返回上個視圖。
ionic官方已經(jīng)定義了常用的行為的優(yōu)先級:
- 返回上個視圖=100;
- 關(guān)閉側(cè)欄菜單=150;
- 關(guān)閉Modal=200;
- 關(guān)閉 action sheet=300;
- 關(guān)閉popup=400;
- 關(guān)閉loading=500;
用法如下:
registerBackButtonAction(callback, priority, [actionId])
所以當(dāng)你要重寫ionic官方定義上面那些行為,你只需要設(shè)置優(yōu)先級大于那些行為的優(yōu)先級即可。比如你要覆蓋的是返回上個視圖的行為,那么你只需要傳入的proirity的值大于100(同時要小于150)即可。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js 判斷當(dāng)前時間是否處于某個一個時間段內(nèi)
這篇文章主要介紹了js 判斷當(dāng)前時間是否處于某個一個時間段內(nèi),使用 jutils - JavaScript常用函數(shù)庫的 isDuringDate 函數(shù)來實現(xiàn),本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09JS實現(xiàn)把鼠標(biāo)放到鏈接上出現(xiàn)滾動文字的方法
這篇文章主要介紹了JS實現(xiàn)把鼠標(biāo)放到鏈接上出現(xiàn)滾動文字的方法,涉及JavaScript響應(yīng)鼠標(biāo)事件動態(tài)操作頁面元素的相關(guān)技巧,需要的朋友可以參考下2016-04-04Bootstrap Tooltip顯示換行和左對齊的解決方案
小編在使用Bootstrap的Tooltip功能時遇到一些小問題,換行丟失,文字不是左對齊。下面小編給大家介紹下Bootstrap Tooltip顯示換行和左對齊的解決方案,感興趣的朋友一起看看吧2017-10-10JavaScript實現(xiàn)解析INI文件內(nèi)容的方法
這篇文章主要介紹了JavaScript實現(xiàn)解析INI文件內(nèi)容的方法,結(jié)合實例形式分析了javascript通過自定義函數(shù)實現(xiàn)針對ini文件解析操作的相關(guān)處理技巧,需要的朋友可以參考下2016-11-11javascript動畫對象支持加速、減速、緩入、緩出的實現(xiàn)代碼
javascript動畫對象支持加速、減速、緩入、緩出的實現(xiàn)代碼,需要的朋友可以參考下2012-09-09