在android平臺(tái)上的app,在主頁(yè)面時(shí)經(jīng)常會(huì)遇到“再按一次退出app”的功能,避免只按一下返回鍵就退出app提升體驗(yàn)優(yōu)化。
1、這個(gè)功能需要我們用到ionic提供的registerBackButtonAction方法(注冊(cè)硬件后退按鈕動(dòng)作)
后退按鈕的優(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è)返回按鈕影響所有頁(yè)面,就要將返回函數(shù)再調(diào)用。
	例如:如果一個(gè)上拉菜單已經(jīng)顯示,后退按鈕應(yīng)該關(guān)閉上拉菜單,而不是返回一個(gè)頁(yè)面視圖或關(guān)閉一個(gè)打開(kāi)的模型。
	所以我們要實(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)用戶在主頁(yè)面, 按返回鍵時(shí),給予提示,如果在2s內(nèi)再次出發(fā)返回鍵,就退出app  function showTipMsg() {   window.plugins.toast.showShortCenter("在按一次退出app"); // toast是cordova的一個(gè)插件cordova-plugin-x-toast,也可以用ionic的彈窗來(lái)代替   $rootScope.exitApp = true;   const delay = 2000;   setTimeout(() => {    $rootScope.exitApp = false;   }, delay);  }    // 判斷當(dāng)前路由,是否是project, mission,mine, message這幾個(gè)主頁(yè)面  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í)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注