>웹 프론트엔드 >CSS 튜토리얼 >'display: inline-block'과 'position:absolute'를 결합하면 높이가 0인 컨테이너가 되는 이유는 무엇입니까?

'display: inline-block'과 'position:absolute'를 결합하면 높이가 0인 컨테이너가 되는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-25 09:04:29651검색

Why Does Combining `display: inline-block` and `position: absolute`  Lead to a Zero Height Container?

CSS 위치 지정 및 인라인 블록 표시 이해

CSS에서 위치 지정 및 표시 속성은 요소가 배열되고 표시되는 방식에 중요한 역할을 합니다. 웹 페이지에서. 이 문서에서는 디스플레이:인라인 블록과 위치:절대를 결합할 때 발생하는 일반적인 문제를 다룹니다.

문제 이해

요소가 절대 위치에 있는 경우(위치:절대) ), 이는 본질적으로 문서의 일반적인 흐름에서 제거됩니다. 이는 더 이상 주변의 다른 요소의 레이아웃에 영향을 미치지 않는다는 것을 의미합니다. 결과적으로, 포함하는 요소가 높이를 고려하지 않아 높이가 0인 컨테이너가 될 수 있습니다.

게다가 절대 위치에 있는 요소에 대해 display:inline-block을 사용하는 것은 의미가 없습니다. 인라인 블록은 문서 내의 요소 흐름에 영향을 미치도록 의도되었지만 절대 위치 지정은 요소를 이 흐름에서 제외시킵니다. 대신 절대 위치 지정 요소는 기본적으로 디스플레이:블록으로 처리됩니다.

절대 위치 지정이 없는 대체 솔루션

두 번째 열에 고정 위치 지정이 필요한 경우 다른 방법이 있습니다. 절대 위치 지정을 사용하지 않고 이를 달성할 수 있는 CSS 접근 방식입니다. 한 가지 옵션은 왼쪽 및 오른쪽 요소 모두에 대해 display:inline-block을 사용하고 고정 너비를 설정하는 것입니다.

.element-left { display: inline-block; width: 200px; }
.element-right { display: inline-block; width: 150px; }

다단계 레이아웃 솔루션

두 번째 열이 왼쪽에 들여쓰기된 텍스트와 함께 수직으로 정렬되어야 하는 더 복잡한 레이아웃의 경우 CSS가 솔루션을 제공할 수도 있습니다.

.element-left { display: inline-block; width: 200px; }
.indent-1 { padding: 10px; }
.indent-2 { padding: 20px; }
.element-right { display: inline-block; width: 150px; }

왼쪽 열 내의 중첩된 요소에 패딩을 사용하여 두 번째 열의 수직 정렬을 유지하면서 들여쓰기 착시 현상이 발생합니다.

결론적으로 CSS의 display:inline-block 및 position:absolute 동작을 이해하는 것은 레이아웃 문제를 해결하는 데 필수적입니다. 대체 접근 방식을 탐색하면 웹 디자인의 기능을 손상시키지 않고 원하는 위치 지정과 레이아웃을 얻을 수 있습니다.

위 내용은 'display: inline-block'과 'position:absolute'를 결합하면 높이가 0인 컨테이너가 되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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