ionic如何監(jiān)聽android返回鍵實(shí)現(xiàn)“再按一次退出”功能-創(chuàng)新互聯(lián)

小編給大家分享一下ionic如何監(jiān)聽android返回鍵實(shí)現(xiàn)“再按一次退出”功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、新吳網(wǎng)絡(luò)推廣、微信平臺(tái)小程序開發(fā)、新吳網(wǎng)絡(luò)營(yíng)銷、新吳企業(yè)策劃、新吳品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供新吳建站搭建服務(wù),24小時(shí)服務(wù)熱線:028-86922220,官方網(wǎng)址:muchs.cn

在android平臺(tái)上的app,在主頁(yè)面時(shí)經(jīng)常會(huì)遇到“再按一次退出app”的功能,避免只按一下返回鍵就退出app提升體驗(yàn)優(yōu)化。

1、這個(gè)功能需要我們用到ionic提供的registerBackButtonAction方法(注冊(cè)硬件后退按鈕動(dòng)作)

  1. registerBackButtonAction(callback, priority, [actionId])

  2. 參數(shù) 類型 說(shuō)明

  3. callback function 當(dāng)點(diǎn)擊返回按鈕時(shí)觸發(fā),如果該監(jiān)視器具有最高的優(yōu)先級(jí)

  4. priority number 僅最高優(yōu)先級(jí)的會(huì)執(zhí)行

  5. 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è)返回按鈕影響所有頁(yè)面,就要將返回函數(shù)再調(diào)用。

例如:如果一個(gè)上拉菜單已經(jīng)顯示,后退按鈕應(yīng)該關(guān)閉上拉菜單,而不是返回一個(gè)頁(yè)面視圖或關(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)用戶在主頁(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的功能"

以上是“ionic如何監(jiān)聽android返回鍵實(shí)現(xiàn)“再按一次退出”功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)頁(yè)題目:ionic如何監(jiān)聽android返回鍵實(shí)現(xiàn)“再按一次退出”功能-創(chuàng)新互聯(lián)
當(dāng)前網(wǎng)址:http://muchs.cn/article24/degpce.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、企業(yè)建站、定制開發(fā)、面包屑導(dǎo)航網(wǎng)站收錄、企業(yè)網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)