Une pièce du puzzle :
/**
* Determines if a form is dirty by comparing the current value of each element
* with its default value.
*
* @param {Form} form the form to be checked.
* @return {Boolean} <code>true</code> if the form is dirty, <code>false</code>
* otherwise.
*/
function formIsDirty(form) {
for (var i = 0; i < form.elements.length; i++) {
var element = form.elements[i];
var type = element.type;
if (type == "checkbox" || type == "radio") {
if (element.checked != element.defaultChecked) {
return true;
}
}
else if (type == "hidden" || type == "password" ||
type == "text" || type == "textarea") {
if (element.value != element.defaultValue) {
return true;
}
}
else if (type == "select-one" || type == "select-multiple") {
for (var j = 0; j < element.options.length; j++) {
if (element.options[j].selected !=
element.options[j].defaultSelected) {
return true;
}
}
}
}
return false;
}
Et un autre :
window.onbeforeunload = function(e) {
e = e || window.event;
if (formIsDirty(document.forms["someForm"])) {
// For IE and Firefox
if (e) {
e.returnValue = "You have unsaved changes.";
}
// For Safari
return "You have unsaved changes.";
}
};
Emballez tout ça, et qu'est-ce que vous obtenez ?
var confirmExitIfModified = (function() {
function formIsDirty(form) {
// ...as above
}
return function(form, message) {
window.onbeforeunload = function(e) {
e = e || window.event;
if (formIsDirty(document.forms[form])) {
// For IE and Firefox
if (e) {
e.returnValue = message;
}
// For Safari
return message;
}
};
};
})();
confirmExitIfModified("someForm", "You have unsaved changes.");
Vous voudrez probablement aussi modifier l'enregistrement de la fonction beforeunload
pour utiliser le gestionnaire d'événement LIBRARY_OF_CHOICE
de l'événement.
0 votes
Je suis intéressé par la même chose, mais pas pour asp.net, mais je pense qu'il existe une solution générale.
0 votes
La solution que j'ai postée ci-dessous peut être utilisée en HTML/Javscript simple. Il suffit de remplacer le "codebehind" par des attributs dans les balises HTML elles-mêmes.
0 votes
Je sais que j'ai 5 ans de retard ici, mais je pense que je peux améliorer les solutions précédentes... Je viens de corriger et mettre à jour ma réponse ci-dessous.