首页 >web前端 >js教程 >如何在 JavaScript 中可靠地捕获窗口关闭事件并执行操作?

如何在 JavaScript 中可靠地捕获窗口关闭事件并执行操作?

Barbara Streisand
Barbara Streisand原创
2024-11-25 19:10:141037浏览

How Can I Reliably Capture Window Close Events in JavaScript and Execute Actions?

捕获窗口关闭事件并在 JavaScript 中执行操作

确定用户何时离开指定页面,特别是通过窗口关闭,可能具有挑战性。以下是如何捕获此事件并执行操作:

现代浏览器(2024 年及以后)

Beacon API 提供了捕获窗口关闭事件的解决方案。 Beacon 请求设计为即使在用户退出页面时也能完成,从而确保可靠的数据收集:

var url = "https://example.com/foo";
var data = "bar";

navigator.sendBeacon(url, data);

事件监控

如果需要在以下位置发起请求最后一刻,监听visibilitychange事件。当页面可见性从活动变为隐藏时触发此事件,表明用户可能已离开页面:

document.addEventListener('visibilitychange', function() {
  if (document.visibilityState === "hidden") {
    // Send beacon request
  }
});

旧版浏览器支持

为了向后兼容,考虑使用lifecycle.js库来管理页面生命周期事件:

lifecycle.addEventListener('statechange', function(event) {
  if (event.originalEvent == 'visibilitychange' && event.newState == 'hidden') {
    var url = "https://example.com/foo";
    var data = "bar";

    navigator.sendBeacon(url, data);
  }
});

注意: 广告拦截器可能会干扰 sendBeacon 请求。考虑使用同源请求或避免通用跟踪 URL。

以上是如何在 JavaScript 中可靠地捕获窗口关闭事件并执行操作?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn