Firefox 및 IE의 "100% 높이" 문제 이해
웹 개발에서 컨테이너 div의 높이를 100%로 설정 내용이 사용 가능한 수직 공간을 완전히 차지하도록 하는 데 자주 사용됩니다. 그러나 사용자는 Firefox 및 Internet Explorer와 같은 다양한 브라우저에서 이 스타일의 동작에 불일치가 발생할 수 있습니다. 일관된 크로스 브라우저 경험을 생성하려면 이러한 차이점 뒤에 숨은 이유를 이해하는 것이 중요합니다.
컨테이너 div에 각각 높이가 100%로 설정된 두 개의 내부 div가 포함된 경우 문제가 발생합니다. Firefox에서 이 스타일은 예상대로 작동하여 내부 div가 컨테이너의 전체 높이까지 늘어납니다. 그러나 Internet Explorer에서는 div가 콘텐츠 높이로 제한됩니다.
이 동작의 원인을 조사하려면 CSS의 "포함 블록" 개념을 고려해야 합니다. 요소의 높이 백분율은 요소의 수직 컨텍스트를 설정하는 상위 요소인 포함 블록의 높이를 기준으로 결정됩니다. 포함 블록의 높이가 명시적으로 지정되지 않은 경우 높이는 내용에 따라 달라집니다.
제공된 CSS 스니펫에서 #container 컨테이너의 높이는 "auto"로 설정되어 있습니다. 고정 높이를 명시적으로 지정합니다. 결과적으로 Firefox에서는 내부 div의 높이가 컨테이너의 자동 높이를 기준으로 계산됩니다. 이로 인해 일반적으로 원하는 100% 높이 동작이 발생합니다.
그러나 Internet Explorer에서 특수 모드 렌더링은 이 동작을 재정의하고 콘텐츠 높이를 기준으로 내부 div의 높이를 계산할 수 있습니다. 결과적으로 div는 컨테이너의 높이를 완전히 차지하지 않고 텍스트 콘텐츠의 높이로 제한됩니다.
일관적인 브라우저 간 호환성을 보장하려면 포함 블록의 높이를 명시적으로 정의하는 것이 중요합니다. 케이스 #컨테이너. #container를 100% 높이로 설정하면 이제 내부 div의 높이가 컨테이너의 고정 높이를 기준으로 계산되므로 Firefox와 Internet Explorer 모두에서 원하는 동작이 발생합니다.
또한, CSS에서 초기 "포함 블록"은 "UA에 종속적"입니다. 즉, 브라우저 구현에 따라 다릅니다. 일관된 참조점을 설정하려면 HTML 및 본문 요소의 높이도 명시적으로 100%로 설정되어야 합니다.
이 지침을 따르면 웹 개발자는 다음과 같은 기능을 통해 디자인이 다양한 브라우저에서 의도한 대로 작동하는지 확인할 수 있습니다. 사용자는 브라우저 선택에 관계없이 원활한 경험을 누릴 수 있습니다.
위 내용은 Firefox와 Internet Explorer에서 '100% 높이'가 다르게 작동하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!