DOM 요소의 표시 속성을 정확하게 검색하는 방법 및 .style 속성이 빈 문자열을 반환할 수 있는 이유

Mary-Kate Olsen
풀어 주다: 2024-10-20 07:13:29
원래의
231명이 탐색했습니다.

How to Accurately Retrieve the Display Property of a DOM Element and Why the .style Property May Return Empty Strings

DOM 요소의 표시 속성 검색: 실제 값 공개

제공된 HTML 코드는 서로 다른 표시를 가진 단락과 앵커를 소개합니다. 스타일. 그러나 스타일 속성을 통해 이러한 스타일을 검색하면 예기치 않은 빈 문자열이 생성되는 것 같습니다. 왜 그런가요? 그리고 어떻게 표시 속성을 정확하게 검색할 수 있나요?

빈 문자열의 수수께끼

초기 혼란은 .style.* 때문에 발생합니다. 속성은 적용된 스타일이 아닌 스타일 속성에 직접 매핑됩니다. 즉, 기본적으로 인라인 스타일 선언을 확인하고 있으며 계산된 스타일이 항상 반영되지 않을 수도 있습니다.

해결책: getCompulatedStyle

실제 적용된 스타일을 얻으려면 , 상속된 속성을 포함하여 getComputeStyle 메서드를 사용해야 합니다. 이 메소드는 DOM 요소를 인수로 사용하고 계산된 스타일 값이 포함된 CSSStyleDeclaration 객체를 반환합니다.

제공된 코드는 다음과 같이 getCompulatedStyle을 사용하도록 수정할 수 있습니다.

<code class="javascript">var a = (document.getElementById('a'));
alert(getComputedStyle(a).display);
var p = (document.getElementById('p'));
alert(getComputedStyle(p).display);
p.style.display = 'none';
alert(getComputedStyle(p).display);</code>
로그인 후 복사

이제 첫 번째 경고는 앵커 태그에 대해 "없음"을 표시하고, 두 번째 경고는 단락 요소에 대해 "차단"을 표시하며, 세 번째 경고는 의도적인 표시 설정 후에 "없음"을 표시합니다. 이는 요소의 계산된 표시 스타일을 정확하게 반영합니다.

대체 접근 방식: 클래스 전환

표시 속성에 의존하는 대신 클래스 이름을 사용하여 전환하는 것을 고려할 수 있습니다. 요소의 가시성. 프레젠테이션을 로직에서 분리하면 코드를 단순화하고 스타일 관련 문제가 발생할 가능성을 줄일 수 있습니다.

위 내용은 DOM 요소의 표시 속성을 정확하게 검색하는 방법 및 .style 속성이 빈 문자열을 반환할 수 있는 이유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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