成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

ionic監(jiān)聽(tīng)android返回鍵(實(shí)現(xiàn)“再按一次退出”功能)

qiangdada / 2953人閱讀

摘要:在平臺(tái)上的,在主頁(yè)面時(shí)經(jīng)常會(huì)遇到再按一次退出的功能,避免只按一下返回鍵就退出提升體驗(yàn)優(yōu)化。如果我們不想注冊(cè)返回按鈕影響所有頁(yè)面,就要將返回函數(shù)再調(diào)用。

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

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

registerBackButtonAction(callback, priority, [actionId])

參數(shù) 類(lèi)型 說(shuō)明

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

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

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ì)注銷(xiāo) 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)用戶(hù)在主頁(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的功能"

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/107437.html

相關(guān)文章

  • ionic監(jiān)聽(tīng)android返回實(shí)現(xiàn)再按一次退出功能

    摘要:在平臺(tái)上的,在主頁(yè)面時(shí)經(jīng)常會(huì)遇到再按一次退出的功能,避免只按一下返回鍵就退出提升體驗(yàn)優(yōu)化。如果我們不想注冊(cè)返回按鈕影響所有頁(yè)面,就要將返回函數(shù)再調(diào)用。 在android平臺(tái)上的app,在主頁(yè)面時(shí)經(jīng)常會(huì)遇到再按一次退出app的功能,避免只按一下返回鍵就退出app提升體驗(yàn)優(yōu)化。 1、這個(gè)功能需要我們用到ionic提供的registerBackButtonAction方法(注冊(cè)硬件后退按鈕動(dòng)...

    gghyoo 評(píng)論0 收藏0
  • Android項(xiàng)目實(shí)戰(zhàn)-博學(xué)谷》底部導(dǎo)航欄

    摘要:底部導(dǎo)航欄布局思路本項(xiàng)目的主界面設(shè)計(jì)了底部導(dǎo)航欄,為了方便后續(xù)布局的搭建,創(chuàng)建一個(gè)底部導(dǎo)航欄的框架,修改主界面布局為,利用包裹標(biāo)題欄與界面內(nèi)容,將各界面內(nèi)容設(shè)置為,再用一個(gè)包裹底部導(dǎo)航欄,在內(nèi)部用三個(gè)來(lái)顯示三個(gè)按鈕具體代碼如下限定大小 底部導(dǎo)航欄布局 思路 本項(xiàng)目的主界面設(shè)計(jì)了底部導(dǎo)航欄,為了方便后續(xù)布局的搭建,創(chuàng)建一個(gè)底部導(dǎo)航欄UI的框架,修改主界面布局為 RelativeLayou...

    余學(xué)文 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<