1

我正在开发一个需要捕获浏览器关闭事件(unloadbeforeunload)的项目。为此,我尝试了下面的代码,但它不起作用。

该代码仅在我打开浏览器控制台窗口(可能只是一秒钟)时才有效,但它是必需的,否则它不起作用。

例子

$(window).on('beforeunload', function(e) {
 $.ajax({
    type: "POST",
    url: "url",
    data : {'value' : 1},
    dataType:'json'
 });
  return false;   
});
4

1 回答 1

2

信标 API 专门用于此目的。在页面卸载时发送请求。 https://developer.mozilla.org/en-US/docs/Web/API/Beacon_API

信标请求使用 HTTP POST 方法,请求通常不需要响应。请求保证在页面被卸载之前被启动并且它们运行完成,而不需要阻塞请求(例如 XMLHttpRequest)。

window.onunload = function analytics(event) {
  if (!navigator.sendBeacon) return;

  var url = "https://example.com/analytics";
  // Create the data to send
  var data = "state=" + event.type + "&location=" + location.href;

  // Send the beacon
  var status = navigator.sendBeacon(url, data);

  // Log the data and result
  console.log("sendBeacon: URL = ", url, "; data = ", data, "; status = ", status);
};
于 2019-11-06T14:55:19.633 回答