国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

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

2019-12-12 01:09:21
字體:
來源:轉載
供稿:網友

在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的功能"

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 甘泉县| 武平县| 阿拉善右旗| 武夷山市| 眉山市| 昭苏县| 康定县| 鱼台县| 册亨县| 天台县| 嘉黎县| 神木县| 肥乡县| 股票| 建瓯市| 濮阳市| 桦南县| 高雄市| 申扎县| 城市| 怀集县| 凤城市| 从江县| 西乌| 五常市| 定陶县| 湄潭县| 灯塔市| 华池县| 新晃| 女性| 北川| 左权县| 米泉市| 合阳县| 民县| 绥江县| 锦州市| 固阳县| 湘乡市| 湛江市|