>  기사  >  웹 프론트엔드  >  CSS 규칙이 있는데도 `element.style.display`가 비어 있는 이유는 무엇입니까?

CSS 규칙이 있는데도 `element.style.display`가 비어 있는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-07 01:20:02931검색

Why is `element.style.display` Empty Even When I Have CSS Rules?

getElementById().style을 사용하여 CSS 스타일 속성이 비어 있는 이유

getElementById()를 활용하여 HTML 요소를 검색하고 해당 요소에 액세스하는 경우 element.style.display를 통한 스타일 속성은 #map {display: block}과 같은 CSS 스타일 규칙이 있음에도 불구하고 종종 빈 값을 반환합니다.

이 동작은 element.style이 인라인 스타일만 명시적으로 반영하기 때문에 발생합니다. HTML 문서 내의 요소에 설정됩니다. 인라인 스타일이 정의되지 않은 경우 element.style은 비어 있습니다.

인라인 스타일과 CSS 규칙을 모두 통합하는 요소의 실제 계산 스타일에 액세스하려면 window.getCompulatedStyle() 메서드를 활용하세요. 이 메소드는 요소에 적용된 전체 스타일을 나타내는 스타일 객체를 제공합니다.

예를 들어 console.log(window.getCompulatedStyle(document.getElementById('test')).display)를 호출하면 "block, " #map {display: block} 규칙을 반영합니다.

CSS를 선호하는 인라인 스타일은 일반적으로 권장되지 않지만, 요소 스타일에 정확하게 액세스하려면 element.style과 window.getCompulatedStyle()의 차이점을 이해하는 것이 중요합니다. 자바스크립트.

위 내용은 CSS 규칙이 있는데도 `element.style.display`가 비어 있는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.