사용자가 form_javascript 기술을 수정했는지 확인하는 JavaScript 방법

WBOY
풀어 주다: 2016-05-16 16:08:47
원래의
1298명이 탐색했습니다.

이 기사의 예에서는 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.";
 }
};
로그인 후 복사

다음은 전체 샘플 코드입니다

코드 복사 코드는 다음과 같습니다.
아래 버튼을 클릭하고 이제 양식에서 일부 값을 변경하고 클릭합니다. 버튼을 다시 누르세요.






          
                                                                                 






함수 formIsDirty(form) {
for (var i = 0; i < form.elements.length; i ) {
var 요소 = form.elements[i];
var 유형 = 요소.유형;
If (유형 == "체크박스" || 유형 == "라디오") {
If (element.checked != element.defaultChecked) {
        true를 반환합니다.
}
}
else if (유형 == "숨김" || 유형 == "비밀번호" ||
유형 == "텍스트" || 유형 == "텍스트 영역") {
If (element.value != element.defaultValue) {
        true를 반환합니다.
}
}
​ else if (type == "select-one" || type == "select-multiple") {
for (var j = 0; j If (element.options[j].selected !=
                element.options[j].defaultSelected) {
          true를 반환합니다.
}
}
}
}
false를 반환합니다.
}

이 기사가 모든 사람의 JavaScript 프로그래밍 설계에 도움이 되기를 바랍니다.

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿