>웹 프론트엔드 >CSS 튜토리얼 >'테두리 상자' 크기 조정에도 불구하고 내 컨테이너가 인라인 블록 요소로 오버플로되는 이유는 무엇입니까?

'테두리 상자' 크기 조정에도 불구하고 내 컨테이너가 인라인 블록 요소로 오버플로되는 이유는 무엇입니까?

DDD
DDD원래의
2024-12-14 09:42:14851검색

Why Does My Container Overflow with Inline-Block Elements Despite `border-box` Sizing?

인라인 블록 요소를 사용한 컨테이너 오버플로 이해

제공된 HTML 및 CSS 코드 조각에서 문제는 인라인 사용으로 인해 발생합니다. 컨테이너 내의 요소를 차단합니다. 기본적으로 특정 브라우저에서는 인라인 블록 요소가 추가 공백과 함께 렌더링됩니다.

공백 소스

이 공백은 인라인 블록 요소의 인라인 특성에서 비롯됩니다. 텍스트 요소의 공백과 줄 바꿈이 눈에 보이는 공간을 만드는 것처럼 인라인 블록 요소에서도 마찬가지입니다. 결과적으로 테두리 상자 크기를 적용하더라도 이 공백으로 인한 예상치 못한 너비로 인해 컨테이너의 오버플로가 발생합니다.

해결책: 공백 제거

이 오버플로 문제를 해결하려면 소스 코드의 인라인 블록 요소 사이에 있는 공백을 모두 제거해야 합니다. 이렇게 하면 브라우저는 추가 공백 없이 요소를 렌더링하여 컨테이너 내에 깔끔하게 맞도록 합니다.

수정된 코드 조각:

.ok {
  width: 300px;
  background: red;
  height: 100px;
  box-sizing: border-box;
}
.box {
  display: inline-block;
  box-sizing: border-box;
  width: 25%;
  border: 2px solid blue;
  height: 100%;
}
<div>

위 내용은 '테두리 상자' 크기 조정에도 불구하고 내 컨테이너가 인라인 블록 요소로 오버플로되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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