이 기사의 예에서는 JavaScript가 사용자가 양식을 수정했는지 여부를 확인하는 방법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 구체적인 분석은 다음과 같습니다.
이 JS 코드는 사용자가 양식 내용을 수정했는지 여부를 확인할 수 있습니다. 양식이 수정되고 브라우저가 종료되면 사용자에게 양식 내용을 저장할지 여부를 알려 주는 매우 유용한 코드입니다.
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; }
사용예: 브라우저를 종료할 때 사용자가 양식을 수정하면 저장할지 여부를 사용자에게 알림
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."; } };
다음은 전체 샘플 코드입니다