這次帶給大家flex佈局詳解,flex佈局詳解的注意事項有哪些,以下就是實戰案例,一起來看一下。
垂直居中是一種常見的頁面佈局方式,對於行內元素可以設定text-align:center;vertical-align:center實現,
而對於區塊級元素通常可以透過以下設定實現
.parent{ position: relative; }.child{ position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); }
然而為了css的簡單優雅,除inline、inline-block、block佈局外,css第四種佈局方式flex應運而生
只需以下設定就可以輕鬆實現元素垂直居中
.parent{ display: flex; justify-content: center; align-items: center; }
注意:設為flex佈局,子元素的float、clear和vertical-align屬性將失效
採用flex佈局的元素,稱為flex容器。元素內所有的子元素稱為flex項目。
容器預設存在兩根軸:水平的主軸(main axis)和垂直的交叉軸(cross axis)。
主軸的起始位置(與邊框的交叉點)叫做main start,結束位置叫做main end;交叉軸的起始位置叫做cross start,結束位置叫做cross end。
專案預設沿著主軸排列,單一專案佔據的主軸空間叫做main size,佔據的交叉軸空間叫做cross size。
flex容器的屬性
flex-direction flex-wrap flex-flow justify-content align-items align-content flex-direction
flex-direction屬性決定主軸的方向。
row(預設值):主軸為水平方向,起點在左端
row-reverse:主軸為水平方向,起點在右端
column:主軸為垂直方向,起點在上方沿
column-reverse:主軸為垂直方向,起點在下沿
flex-wrap
預設情況下,項目都排在主軸線上, flex-wrap屬性定義設定如果一行主軸線排不下,如何換行。
nowrap(預設值):,不換行
wrap :換行,第一行在上邊
wrap-reverse:換行,第一行在下邊
flex-flow
flex-flow屬性是flex-direction屬性和flex-wrap屬性的簡寫形式,
預設值為row nowrap。
justify-content
justify-content屬性定義了項目(自元素)在主軸上的對齊方式。
flex-start(預設值):左對齊
flex-end:右對齊
center: 居中
space-between:兩端對齊,項目之間的間隔都相等。
space-around:每個項目兩側的間隔相等。所以,專案之間的間隔比專案與邊框的間隔大一倍。
align-items
align-items屬性定義項目在交叉軸上如何對齊。
stretch(預設值):如果項目未設定高度或設為auto,將佔滿整個容器的高度。
flex-start:交叉軸的起點對齊。
flex-end:交叉軸的終點對齊。
center:交叉軸的中點對齊。
baseline: 專案的第一行文字的基線對齊。
align-content
align-content屬性定義了多根軸線的對齊方式。如果項目只有一根軸線,則該屬性不起作用。
stretch(預設值):軸線佔滿整個交叉軸。
flex-start:與交叉軸的起點對齊。
flex-end:與交叉軸的終點對齊。
center:與交叉軸的中點對齊。
space-between:與交叉軸兩端對齊,軸線之間的間隔平均分佈。
space-around:每根軸線兩側的間隔都相等。所以,軸線之間的間隔比軸線與邊框的間隔大一倍。
flex項目(自元素)屬性
order flex-grow flex-shrink flex-basis flex align-self order
order屬性定義項目的排列順序。數值越小,排列越前,預設為0。
flex-grow
flex-grow屬性定義項目的放大比例,預設為0,即如果存在剩餘空間,也不放大。
如果所有項目的flex-grow屬性都為1,則它們將等分剩餘空間。
如果一個項目的flex-grow屬性為2,其他項目都是1,則前者佔據的剩餘空間將比其他項多一倍。
flex-shrink
flex-shrink屬性定義了項目的縮小比例,預設為1,即如果空間不足,該項目將縮小。
如果所有項目的flex-shrink屬性都是1,當空間不足時,都會等比例縮小。
如果一個項目的flex-shrink屬性為0,其他項目都是1,則空間不足時,前者不縮小。
負值對該屬性無效。
flex-basis
flex-basis屬性定義了在分配多餘空間之前,專案佔據的主軸空間(main size)。
瀏覽器根據這個屬性,計算主軸是否有多餘空間。它的預設值為auto,即項目的本來大小。
它可以設為跟width或height屬性一樣的值(例如350px),則項目將佔據固定空間。
flex
flex屬性是flex-grow, flex-shrink 和 flex-basis的簡寫,預設值:0 1 auto。後兩個屬性可選。
此屬性有兩個快速值:auto (1 1 auto) 和 none (0 0 auto)。
align-self
align-self屬性允許單一項目有與其他項目不一樣的對齊方式,可覆寫align-items屬性。
預設值:auto,表示繼承父元素的align-items屬性,如果沒有父元素,則等同於stretch。
此屬性可能取6個值,除了auto,其他都與align-items屬性完全一致。
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是flex佈局詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

如何在Quartz中提前發送任務通知在使用Quartz定時器進行任務調度時,任務的執行時間是由cron表達式設定的。現�...


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Atom編輯器mac版下載
最受歡迎的的開源編輯器