찾다
웹 프론트엔드CSS 튜토리얼jQuery의 `height()` 및 `width()`가 `display:none`이 있는 요소에 대해 0이 아닌 값을 반환하는 이유는 무엇입니까?

Why Does jQuery's `height()` and `width()` Return Non-Zero Values for Elements with `display:none`?

"display:none"을 사용하는 jQuery의 특이한 Height() 및 Width() 동작

jQuery의 height() 및 width() 메서드는 다음과 같습니다. 웹페이지에 표시되는 요소의 크기를 결정하는 데 널리 사용됩니다. 그런데 CSS 속성 "display:none"이 설정된 요소를 처리할 때 예상치 못한 동작이 있는 것 같습니다.

질문

전통적으로는 믿어져 왔습니다. "display:none"이 있는 요소의 높이와 너비는 0입니다. 그러나 jQuery의 경우 항상 그런 것은 아닙니다. 다음 예를 고려하십시오.

<code class="html"><div id="target" style="display:none;">
  a
</div></code>
<code class="css">alert($("#target").height());</code>

이 예에서 "대상" 요소의 높이는 0이 아니라 0이 아닌 값입니다. 이러한 불일치는 질문을 제기합니다. 왜 "display:none"이 있는 요소는 때때로 jQuery에서 0이 아닌 높이와 너비를 반환합니까?

대답

이 동작을 이해하려면 , jQuery의 height() 및 width() 메소드의 내부 작동을 조사해야 합니다. 요소의 눈에 보이는 offsetWidth가 0인 경우("숨겨짐"을 나타냄) jQuery는 실제 크기를 계산하려고 시도합니다. 요소의 CSS 속성:

  • position: "absolute"
  • visibility: "hidden"
  • display: "block"
  • 을 일시적으로 재정의하여 이를 수행합니다.

이러한 수정을 통해 jQuery는 필요에 따라 테두리와 패딩을 고려하여 요소의 높이를 검색합니다. 높이가 결정되면 jQuery는 원래 CSS 속성을 복원하여 눈에 보이는 변화가 발생하지 않도록 합니다.

이 프로세스를 통해 상위 요소가 표시되는 한 숨겨진 요소에 대해 height() 및 width()가 올바르게 작동할 수 있습니다. 기본적으로 jQuery는 단일 작업으로 문서 흐름 외부에 요소를 표시하고 해당 크기를 검색한 다음 다시 숨기는 동작을 모두 뒤에서 시뮬레이션합니다. 이렇게 하면 개발자가 치수를 얻기 위해 요소를 수동으로 표시하거나 숨길 필요가 없습니다.

위 내용은 jQuery의 `height()` 및 `width()`가 `display:none`이 있는 요소에 대해 0이 아닌 값을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
앵커 포지셔닝 그냥 소스 순서를 관리하지 마십시오앵커 포지셔닝 그냥 소스 순서를 관리하지 마십시오Apr 29, 2025 am 09:37 AM

앵커 포지셔닝이 HTML 소스 순서를 철회한다는 사실은 컨텐츠와 프리젠 테이션 사이의 또 다른 문제가있는 또 다른 분리 때문에 CSS-Y이기 때문입니다.

마진은 무엇입니까? 40px 100px 120px 80px를 의미합니까?마진은 무엇입니까? 40px 100px 120px 80px를 의미합니까?Apr 28, 2025 pm 05:31 PM

기사는 CSS 마진 속성, 특히 "마진 : 40px 100px 120px 80px", 응용 프로그램 및 웹 페이지 레이아웃에 미치는 영향에 대해 설명합니다.

다른 CSS 테두리 속성은 무엇입니까?다른 CSS 테두리 속성은 무엇입니까?Apr 28, 2025 pm 05:30 PM

이 기사에서는 CSS 국경 속성에 대해 설명하고 사용자 정의, 모범 사례 및 응답성에 중점을 둡니다. 주요 인수 : Border-Radius는 반응 형 디자인에 가장 효과적입니다.

CSS 배경은 무엇이며 속성을 나열합니까?CSS 배경은 무엇이며 속성을 나열합니까?Apr 28, 2025 pm 05:29 PM

이 기사에서는 CSS 배경 속성, 웹 사이트 디자인 향상에 대한 사용 및 피하는 일반적인 실수에 대해 설명합니다. 주요 초점은 배경 크기를 사용한 반응 형 디자인에 중점을 둡니다.

CSS HSL 색상은 무엇입니까?CSS HSL 색상은 무엇입니까?Apr 28, 2025 pm 05:28 PM

기사는 CSS HSL 색상, 웹 디자인에서의 사용 및 RGB의 장점에 대해 설명합니다. 주요 초점은 직관적 인 색상 조작을 통해 설계 및 접근성을 향상시키는 데 있습니다.

CSS에 댓글을 추가 할 수있는 방법은 무엇입니까?CSS에 댓글을 추가 할 수있는 방법은 무엇입니까?Apr 28, 2025 pm 05:27 PM

이 기사는 CSS의 주석 사용에 대해 논의하고 단일 라인 및 멀티 라인 주석 구문을 자세히 설명합니다. 의견은 코드 가독성, 유지 관리 및 협업을 향상 시키지만 제대로 관리하지 않으면 웹 사이트 성능에 영향을 줄 수 있다고 주장합니다.

CSS 선택기는 무엇입니까?CSS 선택기는 무엇입니까?Apr 28, 2025 pm 05:26 PM

이 기사는 CSS 선택기, 유형 및 HTML 요소 스타일링을위한 사용법에 대해 설명합니다. ID와 클래스 선택기를 비교하고 복잡한 선택기의 성능 문제를 해결합니다.

어떤 유형의 CSS가 우선 순위가 가장 높습니까?어떤 유형의 CSS가 우선 순위가 가장 높습니까?Apr 28, 2025 pm 05:25 PM

이 기사는 CSS 우선 순위에 대해 논의하며, 가장 높은 특이성을 가진 인라인 스타일에 중점을 둡니다. CSS 충돌 관리를위한 특이성 수준, 재정의 방법 및 디버깅 도구를 설명합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구