Home > Web Front-end > JS Tutorial > How Can I Reliably Detect Browser Close Events and Handle Unsaved Data?

How Can I Reliably Detect Browser Close Events and Handle Unsaved Data?

DDD
Release: 2024-11-26 17:18:16
Original
933 people have browsed it

How Can I Reliably Detect Browser Close Events and Handle Unsaved Data?

Detecting Browser Close Event

Encountering difficulties in detecting browser close events with customary methods? Fret not, as this detailed guide will provide comprehensive solutions to help you monitor window closure, unloads, or beforeunload events.

解决方案

The following code snippet ingeniously addresses the issue:

window.onbeforeunload = function (event) {
  var message = 'Important: Please click on \'Save\' button to leave this page.';
  if (typeof event == 'undefined') {
    event = window.event;
  }
  if (event) {
    event.returnValue = message;
  }
  return message;
};

$(function () {
  $("a").not('#lnkLogOut').click(function () {
    window.onbeforeunload = null;
  });
  $(".btn").click(function () {
    window.onbeforeunload = null;
  });
});
Copy after login

This solution incorporates the onbeforeunload event handler, which is triggered before the browser window is closed. The message variable displays a custom prompt, informing the user to save data before leaving the page.

Notably, an auxiliary function is included to prevent the prompt from appearing when clicking specific elements on the page (in this case, the #lnkLogOut and .btn elements).

Firefox Compatibility Consideration

While this code generally functions in other browsers, it's important to note that Firefox may not display the custom prompt. In such cases, alternative methods may need to be considered, as discussed in the linked thread.

The above is the detailed content of How Can I Reliably Detect Browser Close Events and Handle Unsaved Data?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template