中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ionic如何監聽android返回鍵實現“再按一次退出”功能

發布時間:2021-07-10 10:46:50 來源:億速云 閱讀:96 作者:小新 欄目:移動開發

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

在android平臺上的app,在主頁面時經常會遇到“再按一次退出app”的功能,避免只按一下返回鍵就退出app提升體驗優化。

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

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

  2. 參數 類型 說明

  3. callback function 當點擊返回按鈕時觸發,如果該監視器具有最高的優先級

  4. priority number 僅最高優先級的會執行

  5. actionId(可空) * 該id指定這個動作 默認: 一個隨機且唯一的id

后退按鈕的優先執行順序:

返回到上一個視圖 = 100

關閉側邊菜單 = 150

關閉模版modal = 200

關閉上拉菜單action sheet = 300

關閉對話框popup = 400

關閉加載框loading = 500

注意:返回: function一個被觸發的函數,將會注銷 backButtonAction。

如果我們不想注冊返回按鈕影響所有頁面,就要將返回函數再調用。

例如:如果一個上拉菜單已經顯示,后退按鈕應該關閉上拉菜單,而不是返回一個頁面視圖或關閉一個打開的模型。
所以我們要實現“再按一次退出app”的功能,可以將優先級priority設為101

2、代碼實現

在js中

angular.module("app").run(["$rootScope", "$ionicPlatform",
 "$location", "$ionicHistory",
 function ($rootScope, $ionicPlatform, $location, $ionicHistory) {
  "use strict";
  
  // 當用戶在主頁面, 按返回鍵時,給予提示,如果在2s內再次出發返回鍵,就退出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);
  }
  
  // 判斷當前路由,是否是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 環境已經準備完畢
  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.");
   }
  });
 }]);

這樣我們就很簡單實現了一個"再按一次退出app的功能"

以上是“ionic如何監聽android返回鍵實現“再按一次退出”功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乡宁县| 陵川县| 巢湖市| 屏边| 濉溪县| 都兰县| 兰溪市| 建瓯市| 万安县| 将乐县| 龙海市| 通辽市| 响水县| 福海县| 黄山市| 财经| 横山县| 应城市| 政和县| 会宁县| 稻城县| 东城区| 金沙县| 新源县| 和龙市| 赤壁市| 双柏县| 沧源| 邮箱| 绥宁县| 阳江市| 昂仁县| 文昌市| 海口市| 托里县| 许昌市| 淅川县| 绥棱县| 射阳县| 峨眉山市| 高安市|