js 控制 history 返回事件2

http://blog.csdn.net/jiangzeyin_/article/details/79186305

上篇博客提供了一种方案去拦截用户返回事件,这里用另一种方案来实现

window.setTimeout(function() {
var m=4;
backfun(m);
window.onpopstate = function() {
    m--;
    if(m==3){
        $(".dd").slideDown();
        $(".mask").show();
        $("body").on("touchmove",function(event){
            event.preventDefault;
        }, false);
    }else if(m==2){
        window.location.href="/dx1sh_back.html";
    }
    backfun(m);
};
function backfun(m){
    //console.log(m);
    history.pushState(null, null, "#tuit"+m);
}
},1000);

onpopstate api 文档如下 https://developer.mozilla.org/zh-CN/docs/Web/API/Window/onpopstate

此方法可以适用于ios 浏览器侧滑返回事件

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在小程序的webview页面中,多层history返回需要通过一些技巧来实现。 首先,我们需要在打开webview页面时,记录下当前页面的url。可以通过监听页面生命周期的方式,当页面加载完成后,获取当前页面的url,并将其存储到某个变量中。 接下来,在webview页面的返回按钮点击事件中,我们可以在每次返回时,通过判断历史记录的长度来决定是返回上一级还是关闭webview页面。 具体的实现逻辑如下: 1. 在小程序中打开webview页面时,使用wx.navigateTo或wx.redirectTo等方法,并在目标页面的onLoad生命周期中获取当前页面的url,并将其存储到某个全局变量中。 2. 在webview页面中,可以通过原生的JavaScript的history对象来控制历史记录的返回。例如,使用history.go(-1)来返回上一级页面。 3. 在webview页面中的返回按钮的点击事件中,我们可以通过去全局变量中获取前面存储的当前页面的url,以及通过JavaScript脚本来获取当前页面的url,进行比较。如果二者一致,说明当前页面是webview页面打开的第一个页面,此时直接关闭webview页面即可;如果不一致,则使用history.go(-1)来返回上一级页面。 需要注意的是,如果webview页面中存在多个层级的历史记录,我们可以通过多次调用history.go(-1)来依次返回上一级页面,直到返回到目标页面为止。 总结而言,小程序中实现webview页面多层历史记录的返回,需要在打开webview页面时记录当前页面的url,并在返回时通过比较当前页面的url来判断是否需要返回上一级页面或者关闭webview页面。通过此方法可以实现多层历史记录的返回功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值