CSS Grid布局:從入門到實戰

CSS Grid布局:從入門到實戰

一、初識Grid布局

還在為網頁布局發愁嗎?Flexbox雖然好用,但當遇到復雜布局時,CSS Grid才是真正的王者。Grid布局是CSS中最強大的二維布局系統,它就像一張無形的網格紙,讓我們可以精準控制每個元素的位置。

.container {display: grid;grid-template-columns: 100px 200px auto;grid-template-rows: 80px auto 60px;gap: 15px;
}

這段簡單的代碼就創建了一個3列3行的網格系統,是不是很像Excel表格?但Grid可比Excel靈活多了!

二、核心概念解析

1. 網格容器(Grid Container)

就像Flexbox需要一個flex容器一樣,Grid布局也需要一個容器元素:

<div class="grid-container"><div class="item1">1</div><div class="item2">2</div><!-- 更多子元素 -->
</div>

2. 網格線(Grid Lines)

網格線是Grid布局的精髓所在。想象一下,網格中的垂直線和水平線都有編號,我們可以通過這些線號來定位元素。

3. 網格軌道(Grid Tracks)

軌道就是相鄰兩條網格線之間的空間,可以是行軌道(row track)或列軌道(column track)。

三、常用屬性詳解

1. 定義網格

.grid-container {display: grid;grid-template-columns: 1fr 2fr 1fr; /* 三列,比例1:2:1 */grid-template-rows: 100px auto 50px; /* 三行 */gap: 10px; /* 行列間距 */
}

fr單位是Grid特有的,表示剩余空間分配比例。

2. 項目定位

.item1 {grid-column: 1 / 3; /* 從第1列線到第3列線 */grid-row: 1; /* 占據第1行 */
}.item2 {grid-area: 2 / 2 / 4 / 3; /* 簡寫:行開始/列開始/行結束/列結束 */
}

四、實戰案例

1. 經典三欄布局

.layout {display: grid;grid-template-areas:"header header header""sidebar main ads""footer footer footer";grid-template-columns: 200px 1fr 200px;grid-template-rows: auto 1fr auto;height: 100vh;
}.header { grid-area: header; }
.sidebar { grid-area: sidebar; }
.main { grid-area: main; }
.ads { grid-area: ads; }
.footer { grid-area: footer; }

2. 響應式圖片墻

.gallery {display: grid;grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));gap: 15px;
}@media (max-width: 600px) {.gallery {grid-template-columns: 1fr;}
}

五、Grid布局小技巧

  1. 命名網格線:給網格線起名字更方便定位

    grid-template-columns: [start] 1fr [center] 1fr [end];
    
  2. 隱式網格:當項目超出定義的范圍時自動創建

    grid-auto-rows: minmax(100px, auto);
    
  3. 對齊方式

    justify-items: center; /* 水平居中 */
    align-items: center; /* 垂直居中 */
    

六、Grid vs Flexbox

  • Flexbox:適合一維布局(行或列)
  • Grid:適合二維布局(行和列)

兩者不是競爭關系,而是互補關系。在實際項目中,我經常在Grid容器中使用Flexbox來排列子元素。

七、瀏覽器兼容性

現代瀏覽器對Grid的支持已經相當完善,包括Edge、Firefox、Chrome、Safari等。對于舊版瀏覽器,可以使用特性查詢(@supports)提供回退方案。

@supports (display: grid) {/* Grid布局樣式 */
}

八、總結

CSS Grid布局徹底改變了我們對網頁布局的認知。從簡單的網格系統到復雜的響應式設計,Grid都能游刃有余。雖然學習曲線略陡峭,但一旦掌握,你會發現它比傳統的浮動、定位布局高效得多。

建議從簡單的布局開始練習,逐步嘗試更復雜的場景。記住,實踐是最好的老師!

小貼士:Chrome瀏覽器的開發者工具中有強大的Grid調試功能,可以幫助你直觀地看到網格線,是學習Grid的絕佳幫手。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/80498.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/80498.shtml
英文地址,請注明出處:http://en.pswp.cn/web/80498.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MongoDB 應用實戰

1. java 原生客戶端 引入maven 1 <dependencies> 2 <dependency> 3 <groupId>org.mongodb</groupId> 4 <artifactId>mongodb‐driver‐sync</artifactId> 5 <version>4.1.1</version> 6 </dependency> 7 </depende…

linux下tcp/ip網絡通信筆記1,

本文章主要為博主在學習網絡通信的筆記一個Udp_echo_server,和client的代碼實現 1&#xff0c;網絡發展&#xff0c;網絡協議&#xff0c;意識到網絡通信——不同主機的進程間通信&#xff0c; 2&#xff0c;學習如何在應用層調用系統提供的接口進行通信&#xff0c;echo_Udp…

前端二進制數據指南:從 ArrayBuffer 到高級流處理

前端開發中&#xff0c;二進制數據是處理文件、圖像、音視頻、網絡通信等場景的基礎。以下是核心概念和用途的通俗解釋&#xff1a; 前端二進制數據介紹 1. 什么是前端二進制數據&#xff1f; 指計算機原始的 0 和 1 格式的數據&#xff08;比如一張圖片的底層代碼&#xff…

Cacti 未經身份驗證SQL注入漏洞

0x00 前言 Cacti是一套基于PHP,MySQL,SNMP及RRDTool開發的網絡流量監測圖形分析工具。 Cacti是通過 snmpget來獲取數據&#xff0c;使用 RRDtool繪畫圖形&#xff0c;而且你完全可以不需要了解RRDtool復雜的參數。 0x01 漏洞描述 漏洞存在于從graph_view.php文件調用的growt…

使用國內源加速Qt在線安裝

簡介&#xff1a; 在線安裝Qt時&#xff0c;會發現下載非常緩慢&#xff0c;可以用過使用國內鏡像源來加速安裝過程。 在線安裝包的下載過程&#xff1a; 1&#xff0c;打開下載頁面 https://www.qt.io/download-open-source 2&#xff0c;點擊 Download the Qt online ins…

C#上位機RS485通信控制變頻器

C#上位機使用Modbus RTU協議控制變頻器 一、RTU報文格式示例 通信命令碼&#xff1a; 03H:讀從機參數 06H:寫從機參數 10H:寫多個參數上位機寫單個寄存器&#xff1a;【從機地址】1字節【命令碼】1字節【寄存器地址高-低】2字節【數據值高-低】2字節【CRC校驗值低-高】…

OCC筆記:Brep格式

1. BREP格式簡介 BREP格式是Open CASCADE內核&#xff08;OCCT&#xff09;的原生數據模型&#xff0c;直接描述幾何體的邊界表示&#xff08;面、邊、頂點拓撲關系及幾何參數&#xff09;。于OCCT內核的算法計算&#xff08;如布爾運算、曲面細分&#xff09;&#xff0c;存儲…

Vue3進行工程化項目,保姆級教學(編譯軟件:vscode)大部分編譯平臺適用

目錄 1. 創建vue工程 1.1 第一步 1.2 選擇名稱和工件 1.3 選擇語言 1.4 自動下載js 1.5 運行vue工程 1.6 成功頁面 2. 更改vue工程安裝的位置 3. 更改運行工程方式 第一步 第二步 ?編輯 第三步 調試 ?編輯 運行項目 前面所學都是vue3的基礎&#xff0c;為了簡…

CSS常用選擇器

CSS選擇器用于選擇HTML元素并為其應用樣式。以下是CSS中最常用的選擇器類型&#xff1a; 基本選擇器 1.元素選擇器 - 通過HTML標簽名選擇元素 p { color: blue; } 2.類選擇器 - 通過class屬性選擇元素&#xff08;以.開頭&#xff09; .warning { color: red; } 3.ID選擇…

EmberGen導出序列圖到UE5

選擇Render節點 調整節點相關參數 然后選擇一個目錄 點擊導出Export Now即可 材質用FlipBook 如果是特效就SubUV

EXCEL Python 實現繪制柱狀線型組合圖和樹狀圖(包含數據透視表)

1、組合圖、數據透視表 &#xff08;1&#xff09;數據預處理 知識點 日期函數 year() month()數據透視表操作 同比計算公式 環比計算公式 &#xff08;2&#xff09;excel 數據透視表插入組合圖 a.2015~2017數據集處理方式&#xff1a; 操作&#xff1a; 結果 b.2020~20…

LabVIEW光譜檢測系統

腔衰蕩光譜技術&#xff08;CRDS&#xff09;憑借高精度和高靈敏度特性&#xff0c;成為微量氣體濃度檢測的常用方法&#xff0c;而準確獲取衰蕩時間是該技術應用的關鍵。基于LabVIEW平臺設計腔衰蕩信號在線處理系統&#xff0c;實現對衰蕩信號的實時采集、平均、擬合、顯示和保…

Flask快速入門和問答項目源碼

Flask基礎入門 源碼&#xff1a; gitee&#xff1a;我愛白米飯/Flask問答項目 - 碼云 目錄 1.安裝環境2.【debug、host、port】3.【路由params和query】4.【模板】5.【靜態文件】6.【數據庫連接】6.1.安裝模塊6.2.創建數據庫并測試連接6.3.創建數據表6.4.ORM增刪改查 6.5.ORM模…

flutter長列表 ListView、GridView、SingleChildScrollView、CustomScrollView區別

組件名稱用途/適合場景是否懶加載支持列表結構用法復雜度SingleChildScrollView適用于內容數量不大、不重復的頁面&#xff08;如表單、靜態內容&#xff09;? 否? 否??ListView適用于垂直方向的長列表&#xff0c;自動滾動&#xff1b;適合展示大量數據? 支持? 是??Li…

鴻蒙OSUniApp 開發的一鍵分享功能#三方框架 #Uniapp

使用 UniApp 開發的一鍵分享功能 在移動應用開發中&#xff0c;分享功能幾乎是必不可少的一環。一個好的分享體驗不僅能帶來更多用戶&#xff0c;還能提升產品的曝光度。本文將詳細講解如何在 UniApp 框架下實現一個簡單高效的一鍵分享功能&#xff0c;適配多個平臺。 各平臺分…

Vue-監聽屬性

監聽屬性 簡單監聽 點擊切換名字&#xff0c;來回變更Tom/Jerry&#xff0c;輸出 你好&#xff0c;Tom/Jerry 代碼 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><title>監聽屬性</title><!-- …

DeepSeek 賦能物聯網:從連接到智能的跨越之路

目錄 一、引言&#xff1a;物聯網新時代的開啟二、DeepSeek 技術揭秘2.1 DeepSeek 是什么2.2 DeepSeek 技術優勢 三、DeepSeek 與物聯網的融合之基3.1 物聯網發展現狀與挑戰3.2 DeepSeek 帶來的變革性突破 四、DeepSeek 在物聯網的多元應用場景4.1 智慧電力&#xff1a;開啟能源…

3.6/Q1,GBD數據庫最新文章解讀

文章題目&#xff1a;Global, regional, and national burden of geriatric depressive disorders in people aged 60 years and older: an analysis of the Global Burden of Disease Study 2021 DOI&#xff1a;10.1186/s12991-025-00560-2 中文標題&#xff1a;60 歲及以上人…

LVGL學習筆記

文章目錄 一、 LVGL移植教程(GD32)一 并行驅動 LED二三一、 LVGL移植教程(GD32) 參考鏈接 1.GD32+LVGL移植教程(超詳細)——基于GD32F303X系列MCU 一 并行驅動 LED 根據您提供的引腳信號(DCLK、DISP、HSYNC、VSYNC、DE),可以判斷這是一款采用 TTL/Parallel RGB 接口…

軟件架構之--論微服務的開發方法1

論微服務的開發方法1 摘要 2023年 2月,本人所在集團公司承接了長三角地區某省漁船圖紙電子化審查系統項目開發,該項目旨在為長三角地區漁船建造設計院、以及漁船圖紙審查機構提供一個便捷的漁船圖紙電子化審查服務平臺。在此項目中,我作為項目組成員參與項目的建設工作,并…