data:image/s3,"s3://crabby-images/5f29d/5f29d4728e7dd565d3128fa3fd876e4a6e21b477" alt="thumbnail"
Box Model이란?
data:image/s3,"s3://crabby-images/92ce5/92ce5ceeffd87c9c6f1b0cef30105506066a64c3" alt="Box model"
브라우저의 렌더링 엔진은 HTML 요소를 나타낼 때 CSS Box Model에 맞춰 그려낸다. 박스 모델은 4가지 영역인 margin, border, padding, content로 구분된다.
content
내용을 표시하는 영역으로, width
와 height
로 크기를 조정할 수 있다.
.box {
width: 250px;
height: 100px;
}
data:image/s3,"s3://crabby-images/5c0f1/5c0f1480e3d016dd4f9ebaad5d17a172616cbe28" alt="content content"
padding
content 주위의 공백을 뜻하며, padding
속성으로 지정할 수 있다.
.box {
width: 250px;
height: 100px;
padding: 50px;
}
data:image/s3,"s3://crabby-images/79792/797927c43f1a297bf7f831f36706e4c4f682ea51" alt="padding padding"
border
content와 padding을 포함하는 영역의 테두리를 지정한다. border
속성을 이용하면 된다.
.box {
width: 250px;
height: 100px;
padding: 50px;
border: 1px solid #000;
}
data:image/s3,"s3://crabby-images/fd5de/fd5de82d459a2fa69eb8fa9cbaa48b90e3f5bc4c" alt="border border"
margin
content, padding, border를 포함한 전체 요소 주위의 공백을 뜻하며, margin
속성으로 지정할 수 있다.
.box {
width: 250px;
height: 100px;
margin: 50px;
padding: 50px;
border: 1px solid #000;
}
data:image/s3,"s3://crabby-images/2b178/2b178c77820189590f8419420c71fe88e0b1797a" alt="margin margin"
box-sizing
박스 모델은 box-sizing
이라는 속성으로 요소의 너비와 높이를 계산하는 방식을 지정할 수 있다. 두 가지 값을 가질 수 있는데, 아래와 같다.
content-box
(default): content 영역만을 기준으로 계산된다.border-box
: padding, border, content 영역을 합한 영역을 기준으로 계산된다.
content-box
content-box
일 경우 width
에 250px 값을 주면 content 영역의 너비만 250px이 되며 padding
과 border
는 별개로 계산된다.
.box {
box-sizing: content-box;
width: 250px;
height: 100px;
margin: 20px;
padding: 10px;
border: 2px solid #000;
}
data:image/s3,"s3://crabby-images/a6782/a678225ed56fc9be8fc2caff82c8ea45976db17f" alt="content-box content-box"
border-box
반면에 border-box
일 경우 width
에 250px 값을 주면 content, padding, border 영역의 너비를 모두 합한 값이 250px이 된다. padding
이 10px, border
가 2px이면 content 영역의 너비는 양쪽 padding, border 값을 제외한 226px이 된다.
.box {
box-sizing: border-box;
width: 250px;
height: 100px;
margin: 20px;
padding: 10px;
border: 2px solid #000;
}
data:image/s3,"s3://crabby-images/feab2/feab264033e809bf1b154e57154386764b8d5d67" alt="border-box border-box"
References
Table Of Contents