"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 두 번 클릭 표시/숨기기 버튼이 두 번째 호출에서만 작동하는 이유는 무엇입니까?

두 번 클릭 표시/숨기기 버튼이 두 번째 호출에서만 작동하는 이유는 무엇입니까?

2024-11-08에 게시됨
검색:799

Why Does a Double-Click Show/Hide Button Only Function on Second Invocation?

처음 사용할 때 버튼 표시/숨기기를 두 번 클릭하는 이유는 무엇입니까?

웹 페이지에서 버튼은 표시하거나 숨기기 위한 것입니다. 요소이지만 초기 호출 시 두 번 클릭해야 합니다. 조사 결과 버튼의 코드는 다음과 같습니다.

function showhidemenu() {
  var x = document.getElementById("menu");
  if (x.style.display === "none") {
    x.style.display = "block";
  } else {
    x.style.display = "none";
  }
}

이 문제는 ID가 'menu'인 요소의 초기 상태에서 발생합니다. 기본적으로 CSS에서 요소의 표시 속성은 "none"으로 설정됩니다. showhidemenu() 함수가 처음 호출되면 다음 확인이 수행됩니다.

if (x.style.display === "none")

이 확인 요소의 초기 표시 속성이 "none"이므로 true로 평가됩니다. 결과적으로 요소의 표시는 "차단"으로 설정됩니다. 그러나 다음 클릭 시 예상대로 표시 속성이 "없음"으로 설정됩니다.

이 문제를 해결하려면 요소의 초기 표시 속성을 "없음" 대신 "비어 있음"으로 설정해야 합니다. 이렇게 하면 첫 번째 클릭 시 함수의 확인이 올바르게 평가됩니다.

if (x.style.display === "none" || x.style.display === "")

이 수정을 통해 의도한 대로 첫 번째 클릭 시 버튼에 요소가 표시됩니다.

릴리스 선언문 이 글은 1729206136에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3