Maison >interface Web >js tutoriel >Méthode JavaScript pour déterminer si l'utilisateur a modifié les compétences form_javascript
L'exemple de cet article décrit comment JavaScript détermine si l'utilisateur a modifié le formulaire. Partagez-le avec tout le monde pour votre référence. L'analyse spécifique est la suivante :
Ce code JS peut déterminer si l'utilisateur a modifié le contenu du formulaire. Si le formulaire est modifié et que le navigateur se ferme, il sera rappelé à l'utilisateur s'il doit enregistrer le contenu du formulaire.
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; }
Exemple d'utilisation : A la sortie du navigateur, si l'utilisateur modifie le formulaire, rappeler à l'utilisateur s'il doit le sauvegarder
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."; } };
Ce qui suit est un exemple de code complet