首頁 web前端 css教學 CSS 網格 – 輕鬆建立複雜佈局

CSS 網格 – 輕鬆建立複雜佈局

Sep 21, 2024 pm 04:18 PM

CSS Grid – Building Complex Layouts with Ease

第 15 講:CSS 網格 – 輕鬆建立複雜佈局

在本次講座中,我們將深入探討 CSS 網格,這是一個強大的佈局系統,可讓您完全控制行和列。雖然 Flexbox 非常適合一維佈局(行或列),但 Grid 可讓您處理二維佈局,這意味著您可以精確地設計整個網頁佈局。

1.什麼是 CSS 網格?

CSS 網格佈局,通常稱為 Grid,是一種 2D 佈局系統,旨在同時管理行和列。您可以將其視為矩陣或電子表格,其中每個元素都放置在網格單元中,從而實現乾淨且有組織的佈局。

2.如何建立網格

要開始使用網格,您需要透過設定 display: grid 將容器定義為網格。然後,您將使用 grid-template-rows 和 grid-template-columns 屬性定義行數和列數。

範例:

<div class="grid-container">
    <div class="item">1</div>
    <div class="item">2</div>
    <div class="item">3</div>
    <div class="item">4</div>
</div>
登入後複製
.grid-container {
    display: grid;
    grid-template-columns: 100px 100px;
    grid-template-rows: 100px 100px;
    gap: 10px; /* space between the grid items */
}

.item {
    background-color: #4CAF50;
    padding: 20px;
    color: white;
    text-align: center;
}
登入後複製

這將建立一個 2x2 網格,每個單元格 100 像素 x 100 像素,單元格之間有 10 像素間隙

3.定義網格區域

您也可以使用 grid-area 屬性為要佔據的項目定義特定的網格區域。這使您可以準確控制項目在網格中的放置位置。

範例:

<div class="grid-container">
    <div class="header">Header</div>
    <div class="sidebar">Sidebar</div>
    <div class="main">Main Content</div>
    <div class="footer">Footer</div>
</div>
登入後複製
.grid-container {
    display: grid;
    grid-template-areas: 
        "header header"
        "sidebar main"
        "footer footer";
    grid-template-columns: 1fr 3fr;
    grid-template-rows: auto 1fr auto;
    gap: 10px;
}

.header {
    grid-area: header;
}

.sidebar {
    grid-area: sidebar;
}

.main {
    grid-area: main;
}

.footer {
    grid-area: footer;
}
登入後複製

此範例建立一個基本佈局,其中頁首和頁尾跨越兩列,側邊欄和主要內容佔據各自的列。 grid-template-areas 屬性可讓您定義網格的結構以及每個區域的名稱。

4.響應式網格的自動調整與自動填充

CSS 網格最好的部分之一是它可以輕鬆實現響應式。自動調整和自動填滿屬性可以根據可用空間自動調整列數。

範例:

.grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 10px;
}
登入後複製

在此範例中,網格將自動建立容器內盡可能多的列,每列至少 150px 寬。如果有多餘的空間,列將拉伸以填滿剩餘區域。

5.網格對齊

您可以使用 justify-itemsalign-items 來對齊網格內的項目。

  • justify-items:在網格單元內水平對齊物品。
  • align-items:在網格單元內垂直對齊物品。

範例:

.grid-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    justify-items: center;
    align-items: center;
    gap: 10px;
}

.item {
    background-color: #FF5722;
    padding: 20px;
    color: white;
    text-align: center;
}
登入後複製

這將使所有項目在其網格單元內水平和垂直居中。

6.巢狀網格

CSS 網格還支援巢狀網格,讓您在網格項目內建立網格以實現更複雜的佈局。

範例:

<div class="grid-container">
    <div class="item">
        <div class="nested-grid">
            <div class="nested-item">Nested 1</div>
            <div class="nested-item">Nested 2</div>
        </div>
    </div>
    <div class="item">Item 2</div>
    <div class="item">Item 3</div>
</div>
登入後複製
.grid-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.nested-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5px;
}

.nested-item {
    background-color: #FFC107;
    padding: 10px;
    color: black;
}
登入後複製

在此範例中,其中一個網格項目包含巢狀網格,允許更靈活和詳細的佈局。

7.網格與 Flexbox:何時分別使用

  • 當您需要管理一個方向(行或列)的專案佈局時,請使用 Flexbox
  • 當您需要同時管理行和列以實現複雜的多維佈局時,請使用網格

結論

CSS 網格是網頁設計的遊戲規則改變者,提供了一種強大的方法來以最少的努力構建複雜且響應式的佈局。無論您是在處理部落格佈局、儀表板還是網站結構,網格都可以讓您靈活地輕鬆控制行和列。


在 LinkedIn 上關注我

裡多伊‧哈桑

以上是CSS 網格 – 輕鬆建立複雜佈局的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1675
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
靜態表單提供商的比較 靜態表單提供商的比較 Apr 16, 2025 am 11:20 AM

讓我們嘗試在這裡造成一個術語:“靜態表單提供商”。你帶上html

使Sass更快的概念證明 使Sass更快的概念證明 Apr 16, 2025 am 10:38 AM

在一個新項目開始時,Sass彙編發生在眼睛的眨眼中。感覺很棒,尤其是當它與browsersync配對時,它重新加載

每周平台新聞:HTML加載屬性,主要的ARIA規格以及從iframe轉移到Shadow dom 每周平台新聞:HTML加載屬性,主要的ARIA規格以及從iframe轉移到Shadow dom Apr 17, 2025 am 10:55 AM

在本週的平台新聞綜述中,Chrome引入了一個用於加載的新屬性,Web開發人員的可訪問性規範以及BBC Move

帶有HTML對話框元素的一些動手 帶有HTML對話框元素的一些動手 Apr 16, 2025 am 11:33 AM

這是我第一次查看HTML元素。我已經意識到了一段時間,但是尚未將其旋轉。它很酷,

紙張形式 紙張形式 Apr 16, 2025 am 11:24 AM

購買或建造是技術的經典辯論。自己構建東西可能會感覺更便宜,因為您的信用卡賬單上沒有訂單項,但是

託管您自己的非JavaScript分析的選項 託管您自己的非JavaScript分析的選項 Apr 15, 2025 am 11:09 AM

有很多分析平台可幫助您跟踪網站上的訪問者和使用數據。也許最著名的是Google Analytics(廣泛使用)

'訂閱播客”鏈接應在哪裡? '訂閱播客”鏈接應在哪裡? Apr 16, 2025 pm 12:04 PM

有一段時間,iTunes是播客中的大狗,因此,如果您將“訂閱播客”鏈接到喜歡:

See all articles