目錄
什麼時候用Grid,什麼時候用Flexbox?
實際怎麼組合使用?看結構
注意點:別搞混了方向和層級
首頁 web前端 css教學 如何使用CSS網格和Flexbox一起教程

如何使用CSS網格和Flexbox一起教程

Jun 27, 2025 am 12:40 AM
flexbox CSS Grid

CSS Grid 和Flexbox 各有專長,配合使用效果最佳。 Grid 是二維佈局,適合整體頁面結構,如頁頭、側邊欄、主內容區、頁腳的安排;Flexbox 是一維佈局,更適合組件內部排列,如導航欄、按鈕組、卡片列表等。例如三欄佈局中間再上下分塊用Grid,幾個按鈕排成一排自動對齊則用Flexbox。實際組合方式為:外層容器用display: grid 定義整體框架,各區域內使用display: flex 排列子元素。常見結構包括頁面整體用Grid 切分區塊,導航條、按鈕組和卡片列表內部用Flexbox 對齊元素。注意點是不要在同一個容器上同時設置Grid 和Flexbox,父級用了Grid 後,子級需單獨設置display: flex 才能生效,嵌套結構中也應避免層級過深導致維護困難。

How to use CSS Grid and Flexbox together tutorial

當你want 做一個現代網頁佈局,CSS Grid 和Flexbox 是兩個最實用的工具。它們各自擅長不同場景,但配合使用時可以解決大多數複雜佈局問題。關鍵不是選誰用誰,而是知道在什麼情況下用哪個。

How to use CSS Grid and Flexbox together tutorial

什麼時候用Grid,什麼時候用Flexbox?

簡單來說: Grid 是二維佈局(行和列一起控制) ,適合整體頁面結構,比如把頁頭、側邊欄、主內容區、頁腳安排好。而Flexbox 是一維佈局(一次只控制一行或一列) ,更適合組件內部排列,比如導航欄、按鈕組、卡片列表等。

How to use CSS Grid and Flexbox together tutorial

舉個例子:

  • 如果你做一個三欄佈局,中間還能上下分塊,那Grid 更合適。
  • 如果你只是想讓幾個按鈕排成一排,並且自動對齊,Flexbox 更直接。

所以,一個完整的頁面裡,你可以外層用Grid 分區域,內部用Flexbox 排元素

How to use CSS Grid and Flexbox together tutorial

實際怎麼組合使用?看結構

常見的做法是:

  • 外層容器用display: grid ,定義整個頁面的框架
  • 每個區域內再使用display: flex來排列子元素

例如:

 .container {
  display: grid;
  grid-template-columns: 200px 1fr 300px;
}

.sidebar {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

這樣左邊欄就變成了垂直分佈的結構,而且不會影響其他區域的佈局方式。

常見組合結構:

  • 頁面整體用Grid 切分區塊
  • 導航條、按鈕組用Flexbox
  • 卡片列表內部用Flexbox 對齊標題、圖片等元素

注意點:別搞混了方向和層級

雖然兩者能一起用,但要注意一些容易出錯的地方:

  • 不要在一個容器上同時設置Grid 和Flexbox,因為只會生效一個
  • 父級用了Grid,子級要用Flexbox 的話,必須單獨給那個子級設置display: flex
  • 在嵌套結構中,盡量保持邏輯清晰,不要層層嵌套太深,否則維護起來麻煩

舉個實際會踩坑的例子:

 <div class="grid-container">
  <div class="flex-box">
    <span>Item 1</span>
    <span>Item 2</span>
  </div>
</div>
 .grid-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.flex-box {
  display: flex;
  gap: 10px;
}

這個寫法沒問題,但如果你不小心在.flex-box上又加了個grid屬性,那它就會變成Grid 容器,Flex 就失效了。


基本上就這些。剛開始可能會覺得有點繞,但只要記住: Grid 控制大結構,Flexbox 負責細節排列,然後在不同層級分開使用,就能輕鬆搞定大多數佈局需求了。

以上是如何使用CSS網格和Flexbox一起教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱門文章

熱工具

記事本++7.3.1

記事本++7.3.1

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

H5中position屬性的靈活運用技巧 H5中position屬性的靈活運用技巧 Dec 27, 2023 pm 01:05 PM

H5中如何靈活運用position屬性在H5開發中,常會涉及到元素的定位和佈局問題。這時候,CSS的position屬性就會發揮作用。 position屬性可以控制元素在頁面中的定位方式,包括相對定位(relative)、絕對定位(absolute)、固定定位(fixed)和黏附定位(sticky)。本文將詳細介紹在H5開發中如何靈活運用position屬性

CSS 佈局屬性最佳化技巧:position sticky 和 ​​flexbox CSS 佈局屬性最佳化技巧:position sticky 和 ​​flexbox Oct 20, 2023 pm 03:15 PM

CSS版面配置屬性最佳化技巧:positionsticky和flexbox在網頁開發中,版面是一個非常重要的面向。良好的佈局結構可以提高使用者體驗,使頁面更加美觀和易於導航。而CSS佈局屬性則是達成此目標的關鍵。在本文中,我將介紹兩種常用的CSS佈局屬性最佳化技巧:positionsticky和flexbox,並提供特定的程式碼範例。一、positions

HTML教學:如何使用Flexbox進行垂直等高佈局 HTML教學:如何使用Flexbox進行垂直等高佈局 Oct 16, 2023 am 09:12 AM

HTML教學:如何使用Flexbox進行垂直等高佈局在Web開發中,佈局一直是個重要的問題。特別是在需要實現垂直等高佈局時,傳統的CSS佈局方法往往會遇到一些困難。而使用Flexbox佈局可以輕鬆解決這個問題。本教學將詳細介紹如何使用Flexbox進行垂直等高佈局,並提供具體的程式碼範例。 Flexbox是CSS3中的新特性,可用於建立靈活的、響應式的佈局。

HTML教學:如何使用Flexbox進行自適應等高等寬等間距佈局 HTML教學:如何使用Flexbox進行自適應等高等寬等間距佈局 Oct 27, 2023 pm 05:51 PM

HTML教學:如何使用Flexbox進行自適應等高等寬等間距佈局,需要具體程式碼範例引言:在現代網頁設計中,佈局是一個非常關鍵的因素。對於需要展示大量內容的頁面來說,如何合理地安排元素的位置和大小,以實現良好的可視性和易用性,是一個重要的問題。 Flexbox(彈性盒佈局)就是一個非常強大的工具,透過它可以輕鬆實現各種靈活的佈局需求。本文將詳細介紹Flexbox

如何使用CSS3的flexbox技術,實現網頁內容的平均分配? 如何使用CSS3的flexbox技術,實現網頁內容的平均分配? Sep 11, 2023 am 11:33 AM

如何使用CSS3的flexbox技術,實現網頁內容的平均分配?隨著網頁設計的發展,人們對於網頁版面的要求也越來越高。為了實現網頁內容的平均分配,CSS3的flexbox技術成為了一個非常有效的解決方案。本文將介紹如何使用flexbox技術來實現網頁內容的平均分配,並給出一些實用的範例。一、什麼是flexbox技術flexbox(彈性佈局)是CSS3新增加的一

HTML教學:如何使用Flexbox進行平均分配佈局 HTML教學:如何使用Flexbox進行平均分配佈局 Oct 16, 2023 am 09:31 AM

HTML教學:如何使用Flexbox進行平均分配版面配置引言:在網頁設計中,經常需要對元素進行佈局。傳統的佈局方法存在一些局限性,而Flexbox(彈性盒子佈局)是一種能夠提供更靈活、更強大的佈局方式。本文將介紹如何使用Flexbox來實現平均分配佈局,同時給出具體的程式碼範例。一、Flexbox簡介Flexbox是CSS3中引入的一種彈性盒子佈局模型,它可以讓元

HTML教學:如何使用Flexbox進行自適應等高佈局 HTML教學:如何使用Flexbox進行自適應等高佈局 Oct 21, 2023 am 10:00 AM

HTML教學:如何使用Flexbox進行自適應等高佈局,需要具體程式碼範例引言:在網頁設計與開發中,實現自適應等高佈局是一項常見的需求。傳統的CSS佈局方法往往在處理等高佈局時面臨一些困難,而Flexbox佈局則為我們提供了一個簡單且強大的解決方案。本文將介紹Flexbox佈局的基本概念和常見用法,並給出具體的程式碼範例,幫助讀者快速掌握使用Flexbox實現自

HTML教學:如何使用Flexbox進行可伸縮等高佈局 HTML教學:如何使用Flexbox進行可伸縮等高佈局 Oct 27, 2023 pm 12:15 PM

HTML教學:如何使用Flexbox進行可伸縮等高佈局,需要具體程式碼範例導語:在網頁佈局中,經常會遇到需要實現等高的佈局效果。傳統的方式比較繁瑣,需要使用JavaScript或table佈局來實作。而使用Flexbox,可輕鬆實現可伸縮的等高佈局,無需依賴其他技術。本篇文章將為大家介紹如何使用Flexbox實現可伸縮的等高佈局,並附上詳細的程式碼範例。一、

See all articles