>웹 프론트엔드 >CSS 튜토리얼 >그리드와 Flexbox

그리드와 Flexbox

王林
王林원래의
2024-09-10 18:00:09788검색

Grid and Flexbox

GridFlexbox는 모두 CSS의 강력한 레이아웃 시스템으로, 각각 다양한 유형의 레이아웃 작업을 위해 설계되었습니다. 다음은 차이점을 설명하는 예와 함께 두 가지를 비교한 것입니다.

플렉스박스

목적:
Flexbox는 1차원 레이아웃을 위해 설계되었습니다. 단일 축(행 또는 열)을 따라 항목의 정렬 및 간격을 처리합니다.

주요 기능:

  • 항목을 가로 또는 세로로 정렬합니다.
  • 컨테이너 내 공간을 분배합니다.
  • 항목 순서와 크기를 유연하게 제어하세요.

예:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Flexbox Example</title>
    <style>
        .container {
            display: flex;
            justify-content: space-between; /* Distributes space between items */
            align-items: center; /* Aligns items vertically in the center */
            height: 100vh;
            background-color: lightgrey;
        }
        .item {
            background-color: dodgerblue;
            color: white;
            padding: 20px;
            text-align: center;
            flex: 1; /* Makes items flexible */
            margin: 10px;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="item">Item 1</div>
        <div class="item">Item 2</div>
        <div class="item">Item 3</div>
    </div>
</body>
</html>

설명된 기능:

  • 항목은 간격을 두고 일렬로 정렬됩니다.
  • 항목은 컨테이너의 세로 중앙에 배치됩니다.
  • 사용 가능한 공간에 따라 항목이 늘어나고 줄어듭니다.

그리드

목적:
그리드는 2차원 레이아웃을 위해 설계되었습니다. 행과 열을 동시에 처리하므로 복잡한 레이아웃이 가능합니다.

주요 기능:

  • 행과 열을 모두 만듭니다.
  • 그리드에서 항목 배치를 제어합니다.
  • 여러 행과 열에 걸쳐 항목을 확장합니다.

예:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Grid Example</title>
    <style>
        .container {
            display: grid;
            grid-template-columns: repeat(3, 1fr); /* Creates three equal-width columns */
            grid-gap: 10px; /* Adds space between grid items */
            height: 100vh;
            background-color: lightgrey;
        }
        .item {
            background-color: dodgerblue;
            color: white;
            padding: 20px;
            text-align: center;
        }
        .item:nth-child(2) {
            grid-column: span 2; /* Makes the second item span two columns */
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="item">Item 1</div>
        <div class="item">Item 2</div>
        <div class="item">Item 3</div>
    </div>
</body>
</html>

설명된 기능:

  • 세 개의 동일한 열로 그리드를 만듭니다.
  • 항목은 간격을 두고 그리드에 배치됩니다.
  • 두 번째 항목은 두 개의 열에 걸쳐 있습니다.

요약

  • Flexbox: 1차원 레이아웃(행 또는 열)에 가장 적합합니다. 항목 정렬, 공간 분배, 간단한 레이아웃 처리에 적합합니다.
  • 그리드: 2차원 레이아웃(행 및 열)에 가장 적합합니다. 두 치수에 대한 정확한 배치와 제어가 필요한 보다 복잡한 설계에 이상적입니다.

Flexbox와 Grid 중에서 선택하는 것은 레이아웃의 복잡성과 1차원 또는 2차원 제어가 필요한지 여부에 따라 다릅니다. 종종 두 가지를 함께 사용하여 원하는 레이아웃을 얻을 수 있습니다.

위 내용은 그리드와 Flexbox의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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