JS监听返回、后退、上一页按钮的事件方法

一、window.history对象

       history.back()   与在浏览器点击后退按钮相同

       histroy.forward()   与在浏览器中点击向前按钮相同

       history.go()   方法中可以填写参数(表示跳转页面的个数)

       由于安全原因javascript不允许修改history里已有的url链接,但可以使用pushState方法往histroy里增加url链接,并且提供popstate事件监测history栈里弹出url。

        pushState方法接受三个参数,依次为:state:一个与指定网址相关的状态对象,poststate事件触发时,该对象会传入回调函数。如果不需要这个对象,此处可以填null。title:新页面的标题,但是所有浏览器目前都忽略这个值,因此这里可以填null,url:新的网址,必须与当前页面处在同一个域,浏览器的地址栏将显示这个网址。pushState()可以创建历史,可以配合popstate事件,可以使用history.go(-1)返回到上一个页面。而replaceState不会加入到历史记录里面,用history.go(-1)会跳过当前页面相当于history.go(-2)。

二、监听返回、后退、上一页按钮监听事件

window.addEventListener("popstate",function(e){

    alert("监听事件成功");
    
},false)

虽然监听了后退事件,如果接着按返回也能回到上一个页面,所以需要使用pushState增加一个本页的url,“#”代表本页

function pushHistory(){

    var state={
        title:"title",
        url:"#"

    };

    window.history.pushState(state,"title","#");

}

 

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 iframe 中返回一页面时,如果不想刷新上一页面,可以使用以下方法: 1. 使用 history.pushState() 方法 在 iframe 中返回一页面时,可以使用 JavaScript 的 history.pushState() 方法修改浏览器历史记录,从而避免刷新上一页面。例如,你可以在子页面中添加以下代码: ```javascript history.pushState(null, null, document.URL); window.addEventListener('popstate', function () { history.pushState(null, null, document.URL); }); ``` 上述代码会在子页面中执行,它会在浏览器历史记录中添加一个新的状态,并且监听 popstate 事件,当用户点击浏览器的后退按钮时,再次调用 pushState() 方法,从而保持历史记录不变。这样就可以实现在 iframe 中返回一页面时不刷新上一页面的效果。 2. 使用 session storage 另一种方法是使用 session storage,在子页面中保存一个标识符,当返回一页面时,检查标识符是否存在,如果存在则不刷新上一页面。例如: 在子页面中添加以下代码: ```javascript sessionStorage.setItem('noRefresh', '1'); ``` 在父页面中添加以下代码: ```javascript window.addEventListener('popstate', function () { var noRefresh = sessionStorage.getItem('noRefresh'); if (noRefresh === '1') { sessionStorage.removeItem('noRefresh'); return; } location.reload(); }); ``` 上述代码会在子页面中设置 sessionStorage,当返回一页面时,父页面会检查 sessionStorage 中是否存在标识符,如果存在则不刷新页面,否则刷新页面。这样就可以实现在 iframe 中返回一页面时不刷新上一页面的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值