搜尋
首頁web前端js教程flex佈局詳解

flex佈局詳解

Mar 13, 2018 pm 06:04 PM
flex佈局詳解

這次帶給大家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中文網其它相關文章!

推薦閱讀:

Javascript的觀察者模式

Javascript的代理模式

Javascript的策略模式

以上是flex佈局詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
使用Next.js(後端集成)構建多租戶SaaS應用程序使用Next.js(後端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:23 AM

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

如何使用Next.js(前端集成)構建多租戶SaaS應用程序如何使用Next.js(前端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:22 AM

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

JavaScript:探索網絡語言的多功能性JavaScript:探索網絡語言的多功能性Apr 11, 2025 am 12:01 AM

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

JavaScript的演變:當前的趨勢和未來前景JavaScript的演變:當前的趨勢和未來前景Apr 10, 2025 am 09:33 AM

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

神秘的JavaScript:它的作用以及為什麼重要神秘的JavaScript:它的作用以及為什麼重要Apr 09, 2025 am 12:07 AM

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

Python還是JavaScript更好?Python還是JavaScript更好?Apr 06, 2025 am 12:14 AM

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

如何安裝JavaScript?如何安裝JavaScript?Apr 05, 2025 am 12:16 AM

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

在Quartz中如何在任務開始前發送通知?在Quartz中如何在任務開始前發送通知?Apr 04, 2025 pm 09:24 PM

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

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

MantisBT

MantisBT

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

SecLists

SecLists

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

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器