"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > CSS 상자 모델 이해: 종합 안내서

CSS 상자 모델 이해: 종합 안내서

2024-07-29에 게시됨
검색:272

Understanding the CSS Box Model: A Comprehensive Guide

CSS 상자 모델은 웹 디자인 및 개발의 기본 개념으로, 요소가 웹 페이지에서 표시되는 방식과 요소가 서로 상호 작용하는 방식을 이해하는 데 중요합니다. 이 문서에서는 CSS 상자 모델을 심층적으로 살펴보고 해당 구성 요소를 설명하며 시각적으로 매력적이고 반응이 빠른 레이아웃을 만들기 위해 이를 조작하는 방법을 설명합니다.

CSS 박스 모델이란 무엇입니까?

CSS 박스 모델은 웹페이지의 요소가 구조화되고 렌더링되는 방식을 설명하는 개념적 프레임워크입니다. 내용, 패딩, 테두리, 여백의 네 가지 구성 요소로 구성됩니다. 이러한 각 구성 요소는 요소의 전체적인 모양과 간격에 중요한 역할을 합니다.

박스 모델의 네 가지 구성 요소

  • 콘텐츠 상자: 텍스트나 이미지 등 실제 콘텐츠가 표시되는 상자의 가장 안쪽 부분입니다. 이 상자의 너비와 높이는 width 및 height 속성을 사용하여 제어할 수 있습니다.
  • 패딩 상자: 패딩은 콘텐츠와 테두리 사이의 공간입니다. 콘텐츠 주위에 내부 쿠션을 만들어 콘텐츠가 테두리에 직접 닿지 않도록 합니다. 패딩은 padding 속성을 이용하여 설정할 수 있으며, 각 변(위, 오른쪽, 아래, 왼쪽)별로 다른 값을 가질 수 있습니다.
  • 테두리 상자: 테두리는 패딩과 콘텐츠를 둘러쌉니다. border-width, border-style 및 border-color와 같은 속성을 사용하여 스타일을 지정할 수 있습니다. 테두리는 각 면에 대해 개별적으로 설정하거나 모든 면에 대해 균일하게 설정할 수 있습니다.
  • 여백 상자: 여백은 상자의 가장 바깥쪽 레이어로, 요소와 인접 요소 사이에 공간을 만듭니다. 여백은 여백 속성을 사용하여 설정되며 각 면마다 다른 값을 가질 수도 있습니다.

박스 모델의 시각적 표현

다음은 CSS 상자 모델을 더 잘 이해하는 데 도움이 되는 시각적 표현입니다.

 ------------------------------- 
|            Margin             |
|   -------------------------   |
|  |         Border          |  |
|  |   -------------------   |  |
|  |  |     Padding       |  |  |
|  |  |   -------------   |  |  |
|  |  |  |   Content   |  |  |  |
|  |  |   -------------   |  |  |
|  |   -------------------   |  |
|   -------------------------   |
 ------------------------------- 

CSS 속성 및 상자 모델

너비 및 높이 설정

기본적으로 너비 및 높이 속성은 콘텐츠 상자에만 적용됩니다. 그러나 box-sizing 속성을 사용하여 이 동작을 변경할 수 있습니다.

.box {
    width: 200px;
    height: 100px;
    box-sizing: content-box; /* Default */
}

.box-border {
    width: 200px;
    height: 100px;
    box-sizing: border-box; /* Includes padding and border in width and height */
}

패딩 추가

패딩은 요소 내부, 콘텐츠 주위에 공간을 추가합니다.

.box {
    padding: 20px; /* Adds 20px padding on all sides */
}

.box-top-bottom {
    padding: 10px 0; /* Adds 10px padding on top and bottom only */
}

테두리 설정
테두리는 너비, 스타일, 색상을 맞춤설정할 수 있습니다.

.box {
    border: 2px solid #333; /* Adds a 2px solid border with a specific color */
}

.box-dashed {
    border: 1px dashed #666; /* Adds a 1px dashed border */
}

여백 관리
여백은 요소 주위에 테두리 외부에 공간을 만듭니다.

.box {
    margin: 20px; /* Adds 20px margin on all sides */
}

.box-horizontal {
    margin: 0 15px; /* Adds 15px margin on left and right only */
}

상자 크기 속성

상자 크기 속성은 요소의 전체 너비와 높이를 계산하는 방법을 결정합니다. 두 가지 주요 값이 있습니다:

  • content-box (기본값): 너비와 높이에는 콘텐츠만 포함됩니다. 안쪽 여백, 테두리 및 여백이 이 상자 외부에 추가됩니다.

  • border-box: 너비와 높이에는 콘텐츠, 패딩 및 테두리가 포함됩니다. 여백은 이 상자 외부에 계속 추가됩니다.

box-sizing 사용: border-box; 특히 반응형 디자인을 다룰 때 더욱 예측 가능한 레이아웃에 권장되는 경우가 많습니다.

* {
    box-sizing: border-box;
}

실제 사례

실제 사례에서 이러한 속성이 어떻게 함께 작동하는지 살펴보겠습니다.



    CSS Box Model

This is a demonstration of the CSS Box Model.

이 예에서 .container 요소의 너비는 300px, 패딩은 20px, 테두리는 5px, 여백은 30px입니다. 요소의 전체 너비는 다음과 같이 계산됩니다.

Total Width = Content Width   Padding   Border
Total Width = 300px   (20px * 2)   (5px * 2) = 350px

결론

CSS 상자 모델을 이해하는 것은 잘 구조화되고 시각적으로 매력적인 웹 페이지를 만드는 데 필수적입니다. 콘텐츠, 패딩, 테두리 및 여백 속성을 마스터하면 요소의 레이아웃과 간격을 효과적으로 제어할 수 있습니다. 상자 크기 조정 속성은 일관된 크기로 반응형 디자인을 만드는 능력을 더욱 향상시킵니다. 이러한 지식을 갖추고 있으면 이제 자신있게 Box 모델을 조작하여 아름답고 기능적인 웹 인터페이스를 구축할 수 있습니다.

릴리스 선언문 이 기사는 https://dev.to/mdhassanpatwary/understanding-the-css-box-model-a-comprehensive-guide-5b94?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다. 그것
최신 튜토리얼 더>
  • EchoAPI와 불면증: 실제 사례를 통한 종합 비교
    EchoAPI와 불면증: 실제 사례를 통한 종합 비교
    풀 스택 개발자로서 저는 API 디버깅, 테스트, 문서화를 위한 최고의 도구를 보유하는 것이 얼마나 중요한지 알고 있습니다. EchoAPI와 Insomnia는 두 가지 뛰어난 옵션으로 각각 고유한 기능과 기능을 갖추고 있습니다. 이러한 도구를 안내하고, 기능과 이점을 ...
    프로그램 작성 2024-11-02에 게시됨
  • 이동 시간 및 기간 | 프로그래밍 튜토리얼
    이동 시간 및 기간 | 프로그래밍 튜토리얼
    소개 이 랩의 목표는 Go의 시간 및 기간 지원에 대한 이해도를 테스트하는 것입니다. 시간 아래 코드에는 Go에서 시간과 기간을 사용하는 방법에 대한 예가 포함되어 있습니다. 그러나 코드의 일부가 누락되었습니다. 귀하의 임무는 예상대로 작...
    프로그램 작성 2024-11-02에 게시됨
  • 호이스팅 면접 질문 및 답변
    호이스팅 면접 질문 및 답변
    1. 자바스크립트에서 호이스팅이란 무엇인가요? 답변: 호이스팅은 변수와 함수에 메모리가 할당되는 실행 컨텍스트 생성 단계의 프로세스입니다. 이 프로세스 동안 변수에 대한 메모리가 할당되고 변수에는 정의되지 않은 값이 할당됩니다. 함수의 경우 전체 함수 ...
    프로그램 작성 2024-11-02에 게시됨
  • JavaScript의 DOM(문서 개체 모델) 이해
    JavaScript의 DOM(문서 개체 모델) 이해
    안녕하세요, 놀라운 JavaScript 개발자 여러분? 브라우저는 스크립트(특히 JavaScript)가 웹 페이지 레이아웃과 상호 작용할 수 있도록 하는 DOM(문서 개체 모델)이라는 프로그래밍 인터페이스를 제공합니다. 페이지의 구성 요소를 개체로 배열...
    프로그램 작성 2024-11-02에 게시됨
  • SPRING BATCH로 프로그래밍 시작
    SPRING BATCH로 프로그래밍 시작
    Introduction Dans vos projets personnels ou professionnels, Il vous arrive de faire des traitements sur de gros volumes de données. Le traite...
    프로그램 작성 2024-11-02에 게시됨
  • CSS로 Github 프로필을 돋보이게 만드세요
    CSS로 Github 프로필을 돋보이게 만드세요
    이전에는 Github 프로필을 맞춤 설정할 수 있는 유일한 방법은 사진을 업데이트하거나 이름을 변경하는 것이었습니다. 이는 모든 Github 프로필이 동일해 보이고 이를 사용자 정의하거나 눈에 띄게 하는 옵션이 최소화되었음을 의미합니다. 이후부터 Markdown을 사용...
    프로그램 작성 2024-11-02에 게시됨
  • TypeScript 유틸리티 유형: 코드 재사용성 향상
    TypeScript 유틸리티 유형: 코드 재사용성 향상
    TypeScript는 개발자가 유형을 효과적으로 변환하고 재사용할 수 있는 내장 유틸리티 유형을 제공하여 코드를 더욱 유연하고 DRY하게 만듭니다. 이 기사에서는 TypeScript 기술을 다음 단계로 끌어올리는 데 도움이 되는 Partial, Pick, Omit 및 ...
    프로그램 작성 2024-11-02에 게시됨
  • 텔레그램 window.open(url, &#_blank&#); iOS에서는 이상하게 작동합니다
    텔레그램 window.open(url, &#_blank&#); iOS에서는 이상하게 작동합니다
    텔레그램 봇을 만들고 있는데 미니앱의 일부 정보를 채팅으로 전달하는 옵션을 추가하고 싶습니다. 나는 window.open(url, '_blank');를 사용하기로 결정했습니다. iPhone에서 사용해 보기 전까지는 잘 작동했습니다. 전달하는 대신 공유 기...
    프로그램 작성 2024-11-02에 게시됨
  • 프론트엔드 개발자는 누구인가요?
    프론트엔드 개발자는 누구인가요?
    오늘날 인터넷상의 모든 웹사이트나 플랫폼의 사용자 인터페이스 부분은 프런트 엔드 개발자의 작업 결과입니다. 이들은 사용자 친화적인 인터페이스를 만드는 데 참여하여 사이트의 모양과 기능을 보장합니다. 그렇다면 프론트엔드 개발자는 정확히 누구일까요? 간단하게 설명드리겠습니...
    프로그램 작성 2024-11-02에 게시됨
  • 보존된 CSS 스타일을 사용하여 HTML 콘텐츠를 PDF로 저장하는 방법은 무엇입니까?
    보존된 CSS 스타일을 사용하여 HTML 콘텐츠를 PDF로 저장하는 방법은 무엇입니까?
    CSS가 포함된 HTML 콘텐츠를 PDF로 저장웹 개발에서는 콘텐츠를 다른 형식으로 내보낼 때에도 시각적 미학을 유지하는 것이 중요합니다. 변환 프로세스 중에 CSS 스타일이 손실될 수 있으므로 HTML 요소를 PDF로 저장하려고 할 때 문제가 발생할 수 있습니다.저장...
    프로그램 작성 2024-11-02에 게시됨
  • Print_r()을 사용할 때 왜 팬텀 속성이 DateTime 객체에 추가됩니까?
    Print_r()을 사용할 때 왜 팬텀 속성이 DateTime 객체에 추가됩니까?
    Print_r() DateTime 객체 변경Print_r()는 DateTime 객체에 속성을 추가하여 디버깅 중에 자체 검사를 활성화합니다. PHP 5.3에 도입된 내부 기능의 부작용인 이 동작은 텍스트에 덤프된 인스턴스에 가상 공용 속성을 할당합니다.이러한 속성으로 ...
    프로그램 작성 2024-11-02에 게시됨
  • C의 데이터 구조 및 알고리즘: 초보자에게 친숙한 접근 방식
    C의 데이터 구조 및 알고리즘: 초보자에게 친숙한 접근 방식
    C에서는 데이터 구조와 알고리즘을 사용하여 데이터를 구성, 저장 및 조작합니다. 데이터 구조: 배열: 정렬된 컬렉션, 요소에 액세스하기 위해 인덱스 사용 연결 목록: 포인터를 통해 요소 연결, 동적 길이 지원 스택: FILO(선입선출) 원칙 큐: FIFO(선입선출) 원...
    프로그램 작성 2024-11-02에 게시됨
  • ## `has_key()` 또는 `in`?  Python에서 사전 키를 확인하는 가장 좋은 방법은 무엇입니까?
    ## `has_key()` 또는 `in`? Python에서 사전 키를 확인하는 가장 좋은 방법은 무엇입니까?
    Python에서 사전 키 확인을 위해 'has_key()'와 'in' 중에서 선택 Python 사전의 특정 키, 'has_key()' 및 'in' 모두 실행 가능한 옵션을 제공합니다. 그러나 선호되는 방법은 시간...
    프로그램 작성 2024-11-02에 게시됨
  • AJAX를 사용하여 JSON 데이터를 PHP로 보내는 방법은 무엇입니까?
    AJAX를 사용하여 JSON 데이터를 PHP로 보내는 방법은 무엇입니까?
    Ajax를 사용하여 JSON 데이터를 PHP로 전송하는 방법JSON 형식으로 PHP 스크립트에 데이터를 전달하려면 다음이 중요합니다. AJAX를 사용하여 효과적으로 데이터를 보낼 수 있습니다.JSON 데이터 보내기제공된 코드는 AJAX를 사용하여 JSON 데이터를 보내...
    프로그램 작성 2024-11-02에 게시됨
  • JS: 약속인가, 콜백인가?
    JS: 약속인가, 콜백인가?
    JavaScript의 Promise와 Callback 이해하기 인증 테스트에 대한 주요 질문 및 답변 콜백 함수란 무엇이며 일반 함수와 어떻게 다릅니까? 콜백 함수는 다른 함수에 인수로 전달되고 비동기 작업을 처리하기 위해 호출됩니다. 일...
    프로그램 작성 2024-11-02에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3