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

本文介绍了如何利用JavaScript的history.pushState方法来监听和处理浏览器的返回、后退和上一页操作。通过pushState可以往历史记录中添加新的URL,并结合popstate事件进行监控。history.back()和history.forward()分别模拟后退和前进,history.go()用于跳转指定页数。同时,文章提到了安全限制,即不能修改已有的URL,但可以创建新的历史记录。案例中展示了pushState的实际应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原理:主要是通过pushState方法往histroy里增加url链接,并且提供popstate事件监测history栈里弹出url

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)。

history.pushState(stateObject, title, url);

history.pushState()主要是在不刷新浏览器的情况下,创建新的浏览记录并插入浏览记录队列中。

1.状态对象(stateObject)--stateObject是一个JavaScript对象,通过pushState方法可以将stateObject内容传递到新页面中。

2.标题(title)--几乎没有浏览器支持该参数,但是传一个空字符串会比较安全。

3.地址(url)--新的历史记录条目的地址(可选,不指定的话则为文档当前URL);浏览器在调用pushState()方法后不会加载该地址;传入的URL与当前URL应该是同源的,否则,pushState()会抛出异常。

案例:

a.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div onclick="pushHistory()">
        监听页面回退就到附近奥加饭酒
        <a href="./index.html">去a页面</a>
    </div>
    <script>
        function pushHistory() {
            console.log(22222222)
            var state = {
                title: "title",
                url: "b.html"
            };
            window.history.pushState(state, "title", "b.html");
        }
    </script>
</body>

</html>

b.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div onclick="pushHistory()">
        监听页面回退
    </div>
    <script>
        window.onload = function () {
            console.log(111111)
        }

        function pushHistory() {
            console.log(22222222)
            var state = {
                title: "title",
                url: "#"
            };
            // 第二种写法:
            // window.history.pushState({
            //     status: 0
            // }, '', '?data=1')
            window.history.pushState(state, "title", "a.html");
        }
        window.addEventListener("popstate", function (e) {
            console.log(2222)
            alert("我监听到了浏览器的返回按钮事件啦"); //根据自己的需求实现自己的功能 
            pushHistory()
        }, false);
    </script>
</body>

</html>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值