phonegap监听backbutton点击事件后,其他页面点击回退键出现无反应现象

文章详细介绍了在使用PhoneGap开发跨页面应用时遇到回退键事件冲突的问题,并提供了通过在每个页面加载cordova.js并初始化来解决此问题的方法。
phonegap版本:4.2.0

问题描述:
比如我们有三个页面,分别是main.html,page1.html,page2.html。我们有这样的需求:当在main.html页面点击回退键时要退出程序(默认是返回上一页),在page1.html或者page2.html上点回退键依然是返回上一页。自然而然,我们想到的是在main.html页面加上回退键监听事件,捕捉到后退出程序。于是我在main.html页面加上了下面的代码
document.addEventListener("backbutton", onBackKeyDown, false);
var shouldExit = false;
function onBackKeyDown() {
    if (shouldExit) {
        navigator.app.exitApp();
    } else {
        shouldExit = true;
        window.plugins.toast.showShortBottom('再点击一次退出程序!', function(){}, function(){});
        setInterval(function(){
            shouldExit = false;
        }, 3000);
    }
}
在main.html页面测试,点击两次返回键退出程序,没问题。
但是,但是。。。我从main.html点击链接跳到page1.html或者page2.html后,再点击回退键竟然回不去了,也就是点击回退键在除了main.html这个页面以外都没反应了!
后来看了下phonegap的代码,发现是这样:
第一次绑定backbutton的监听函数后,cordova.js就会通知app,backbutton事件被重写了,所以不管载入什么页面app默认的backbutton事件都不会触发了,要通过cordova.js告诉app解除backbutton重写。

解决办法:
查了很多资料发现没有很好的解决办法,最后我的解决方法就是在每个页面都载入cordova.js,然后在cordova.js的初始化方法里先解除backbutton事件的重写,这样在没有监听backbutton事件的页面,点击回退键依然会触发默认事件(返回上一页)


大家如果有更好的方法,也欢迎探讨。个人邮箱towardsyoung@sina.com
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值