>웹 프론트엔드 >CSS 튜토리얼 >'왼쪽: 50%'가 올바르게 작동하는데 '위쪽: 50%'가 내 요소를 수직으로 가운데에 배치하지 않는 이유는 무엇입니까?

'왼쪽: 50%'가 올바르게 작동하는데 '위쪽: 50%'가 내 요소를 수직으로 가운데에 배치하지 않는 이유는 무엇입니까?

DDD
DDD원래의
2024-11-17 05:22:03776검색

Why Does

CSS top 백분율이 예상대로 작동하지 않음: 이유 탐구

반응형 레이아웃을 추구하다가 "top :50%"는 예상대로 작동하지 않지만 "left:50%"는 문제 없이 작동합니다. 왜 이런 일이 발생합니까?

동작을 이해하려면 다음 상위 및 하위 요소 구조를 고려하십시오.

<div>

문제 해결의 핵심은 "top" 속성이 어떻게 작동하는지 이해하는 데 있습니다. CSS. "50%"와 같은 백분율을 지정하면 상위 컨테이너의 높이를 기준으로 계산됩니다. 그러나 이 시나리오에서는 상위 컨테이너에 명시적으로 높이가 정의되어 있지 않으므로 "top" 속성은 알 수 없는 값에 대해 효과적으로 계산됩니다.

이 문제를 해결하려면 상위 컨테이너에 대해 고정 높이를 설정해야 합니다. . 이는 하위 요소의 상단 위치에 필요한 참조 지점을 제공합니다.

예 1: 높이 정의

<div>

상위 요소에 200px의 높이를 제공합니다. div의 경우 하위 div의 상단 위치가 이제 200px의 50%로 올바르게 계산되어 예상되는 수직 위치가 됩니다.

예 2: 컨테이너 늘리기

대체 접근 방식은 사용 가능한 전체 공간을 차지하도록 상위 컨테이너를 늘리는 것입니다.

<div>

컨테이너의 위쪽, 아래쪽, 왼쪽 및 오른쪽 속성을 정의하면 사용 가능한 공간을 채울 수 있도록 확장됩니다. 그런 다음 확장된 컨테이너를 기준으로 하위 div의 상단 위치가 계산되어 동일한 센터링 효과를 얻을 수 있습니다.

위 내용은 '왼쪽: 50%'가 올바르게 작동하는데 '위쪽: 50%'가 내 요소를 수직으로 가운데에 배치하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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