浏览器回退事件

监听浏览器后退按钮实现翻页回退


监听浏览器回退事件

百度找了很多,资源比较少。


一、对浏览器回退事件监听

代码如下(示例):

window.addEventListener("popstate", function(e) { 
alert("我监听到了浏览器的返回按钮事件啦");//根据自己的需求实现自己的功能 
}, false);

二、创建一个本页的url

虽然我们监听到了后退事件,但是页面还是会返回上一个页面,所以我们需要使用pushState增加一个本页的url,代表本页

1.添加记录

代码如下(示例):

function pushHistory() { 
var state = { 
title: "title", 
url: "#"
}; 
window.history.pushState(state, "title", "#"); 
}

2.整体代码

代码如下(示例):

$(function(){ 
pushHistory(); 
window.addEventListener("popstate", function(e) { 
alert("我监听到了浏览器的返回按钮事件啦");//根据自己的需求实现自己的功能 
}, false); 
function pushHistory() { 
var state = { 
title: "title", 
url: "#"
}; 
window.history.pushState(state, "title", "#"); 
} 
});

三、根据需求进行修改

1.在翻页时,进行对页数的保存

我们可以利用数组来进行对翻页的当前页数进行保存,我这里使用的是 bootstrapTable组件

//创建一个数组
var arr = [];
//初始页
arr.push(1);
$('#Table').on( 'page-change.bs.table', function ( e, number, size ) {
    //定位第几页
    arr.push(number)
} );

2.在后退事件监听中进行页数跳转.

后退到第一次翻页记录的时候,返回至首页

//监听返回
    window.addEventListener("popstate", function (e) {
        if (arr.length==1){
            location.href='首页地址';
        }
        $('#Table').bootstrapTable('selectPage',arr[arr.length-2]);
        //除去最后一位数据两次,因为执行了翻页方法后又把当前页添加进了数组
        arr.pop();
        arr.pop();
    }, false);

这样就实现后退,返回上一次翻页记录。


总结

需要注意的地方,一定得给本页添加一个history的连接,不然的话不起作用。灵活运用可以实现不同的功能。

资料参考:https://www.cnblogs.com/yangjing1314/p/10189241.html

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值