js监听浏览器后退事件

来源:互联网 发布:给男朋友织围巾知乎 编辑:程序博客网 时间:2024/05/18 21:48

最近需求需要,需在浏览器(web 和 h5手机端)实现回退弹框

网上很少找到这个需求,找到的也是有bug的,最后解决了,分享一下问题和解决方案

用到的函数:window.history.pushState

网上有个方法测试了一下:

$(document).ready(function(e) {             var counter = 0;            if (window.history && window.history.pushState) {                             $(window).on('popstate', function () {                                            window.history.pushState('forward', null, '#');                                            window.history.forward(1);                                          alert("不可回退");                                });              }              window.history.pushState('forward', null, '#'); //在IE中必须得有这两行              window.history.forward(1);});

有一个bug就是手机上面不能正常的弹框

在网上找了一下问题,分享文章:popstate事件在webkit中的诡异行为

解决方法:设置了一个siteTimeout,本人刚测试的时候,设置了一个setTimeout=1也不知道为什么还是无效,于是把时间改成了1000,可以正常弹框了.(不过是为什么会有这个原因,具体还没有查到,因为有的设置1是可以正常弹框了,有知道为什么的可以告知一下)

我的解决方案的js:

"pushState" in window.history && (        window.history.pushState({            title: document.title,            url: location.href        }, document.title, location.href),            setTimeout(function () {                window.addEventListener("popstate", function (a) {                    var is_guest = <?php echo $is_guest;?>;                    if (is_guest == 1) {                        $('.pop_UpLevel').show(); //弹框的需求                    } else {                        $('.pop_more').show();                    }                    return false;                })            }, 1000)    );
问题:用这个方法,就是每次点击别的弹框,也会出现后退的这个弹框的需求(本人未解决,所以用了一个比较笨的方法,就是每次别的样式的弹框都对退后的弹框hide,有点笨,但是解决了问题)

嘻嘻,如果有上面2个问题的解决方案的牛牛,也告知一下我,互相学习一下,谢谢啦~~~~~~


0 0
原创粉丝点击