js如何监听用户的刷新操作?

发布于 2022-09-02 01:39:09 字数 559 浏览 5 评论 0

百度了一下,搜到的代码好像不起作用
搜到的代码如下:

window.onbeforeunload = function() {
    var n = window.event.screenX - window.screenLeft;
    var b = n > document.documentElement.scrollWidth-20;
    if(b && window.event.clientY < 0 || window.event.altKey){
        alert("这是一个关闭操作而非刷新");
        //此处放你想要操作的代码
    }else{
        alert("这是一个刷新操作而非关闭");
    }
} 

上面这段代码我刷新页面或者关闭标签都没有alert,不知道是哪里出了问题?
还有一个问题是,可以做到只监听用户用F5刷新么?直接在地址栏回车不需要监听,该怎么做呢?

补充:只需ChromeSafari可运行即可

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

巨坚强 2022-09-09 01:39:09

只监听用户用F5刷新
检测F5的keypress keydown等事件,检测是否被摁下

妞丶爷亲个 2022-09-09 01:39:09

对于设置了缓存日期的js文件来说 输入页面网址和点击链接跳转等行为会直接读缓存,只有刷新才会向服务器发请求,可利用比特性实现刷新后的检测

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文