FLEX 布局

網頁布局(layout)是CSS的一個重點應用。

布局的傳統解決方案,基于盒狀模型,依賴?display屬性 +?position屬性 +?float屬性。它對于那些特殊布局非常不方便,比如,垂直居中就不容易實現。

2009年,W3C提出了一種新的方案----Flex布局,可以簡便、完整、響應式地實現各種頁面布局。目前,它已經得到了所有瀏覽器的支持,這意味著,現在就能很安全地使用這項功能。

Flex布局將成為未來布局的首選方案。本文介紹它的語法,下一篇文章給出常見布局的Flex寫法。

以下內容主要參考了下面兩篇文章:A Complete Guide to Flexbox?和?A Visual Guide to CSS3 Flexbox Properties。

一、Flex布局是什么?

Flex是Flexible Box的縮寫,意為"彈性布局",用來為盒狀模型提供最大的靈活性。

任何一個容器都可以指定為Flex布局。


.box{display: flex; } 

行內元素也可以使用Flex布局。


.box{display: inline-flex; } 

Webkit內核的瀏覽器,必須加上-webkit前綴。


.box{display: -webkit-flex; /* Safari */ display: flex; } 

注意,設為Flex布局以后,子元素的floatclearvertical-align屬性將失效。

二、基本概念

采用Flex布局的元素,稱為Flex容器(flex container),簡稱"容器"。它的所有子元素自動成為容器成員,稱為Flex項目(flex item),簡稱"項目"。

容器默認存在兩根軸:水平的主軸(main axis)和垂直的交叉軸(cross axis)。主軸的開始位置(與邊框的交叉點)叫做main start,結束位置叫做main end;交叉軸的開始位置叫做cross start,結束位置叫做cross end

項目默認沿主軸排列。單個項目占據的主軸空間叫做main size,占據的交叉軸空間叫做cross size

三、容器的屬性

以下6個屬性設置在容器上。

  • flex-direction
  • flex-wrap
  • flex-flow
  • justify-content
  • align-items
  • align-content

3.1 flex-direction屬性

flex-direction屬性決定主軸的方向(即項目的排列方向)。


.box {flex-direction: row | row-reverse | column | column-reverse; } 

它可能有4個值。

  • row(默認值):主軸為水平方向,起點在左端。
  • row-reverse:主軸為水平方向,起點在右端。
  • column:主軸為垂直方向,起點在上沿。
  • column-reverse:主軸為垂直方向,起點在下沿。

3.2 flex-wrap屬性

默認情況下,項目都排在一條線(又稱"軸線")上。flex-wrap屬性定義,如果一條軸線排不下,如何換行。


.box{flex-wrap: nowrap | wrap | wrap-reverse; } 

它可能取三個值。

(1)nowrap(默認):不換行。

(2)wrap:換行,第一行在上方。

(3)wrap-reverse:換行,第一行在下方。

3.3 flex-flow

flex-flow屬性是flex-direction屬性和flex-wrap屬性的簡寫形式,默認值為row nowrap


.box {flex-flow: <flex-direction> || <flex-wrap>; } 

3.4 justify-content屬性

justify-content屬性定義了項目在主軸上的對齊方式。


.box {justify-content: flex-start | flex-end | center | space-between | space-around; } 

它可能取5個值,具體對齊方式與軸的方向有關。下面假設主軸為從左到右。

  • flex-start(默認值):左對齊
  • flex-end:右對齊
  • center: 居中
  • space-between:兩端對齊,項目之間的間隔都相等。
  • space-around:每個項目兩側的間隔相等。所以,項目之間的間隔比項目與邊框的間隔大一倍。

3.5 align-items屬性

align-items屬性定義項目在交叉軸上如何對齊。


.box {align-items: flex-start | flex-end | center | baseline | stretch; } 

它可能取5個值。具體的對齊方式與交叉軸的方向有關,下面假設交叉軸從上到下。

  • flex-start:交叉軸的起點對齊。
  • flex-end:交叉軸的終點對齊。
  • center:交叉軸的中點對齊。
  • baseline: 項目的第一行文字的基線對齊。
  • stretch(默認值):如果項目未設置高度或設為auto,將占滿整個容器的高度。

3.6 align-content屬性

align-content屬性定義了多根軸線的對齊方式。如果項目只有一根軸線,該屬性不起作用。


.box {align-content: flex-start | flex-end | center | space-between | space-around | stretch; } 

該屬性可能取6個值。

  • flex-start:與交叉軸的起點對齊。
  • flex-end:與交叉軸的終點對齊。
  • center:與交叉軸的中點對齊。
  • space-between:與交叉軸兩端對齊,軸線之間的間隔平均分布。
  • space-around:每根軸線兩側的間隔都相等。所以,軸線之間的間隔比軸線與邊框的間隔大一倍。
  • stretch(默認值):軸線占滿整個交叉軸。

四、項目的屬性

以下6個屬性設置在項目上。

  • order
  • flex-grow
  • flex-shrink
  • flex-basis
  • flex
  • align-self

4.1 order屬性

order屬性定義項目的排列順序。數值越小,排列越靠前,默認為0。


.item {order: <integer>; } 

4.2 flex-grow屬性

flex-grow屬性定義項目的放大比例,默認為0,即如果存在剩余空間,也不放大。


.item {flex-grow: <number>; /* default 0 */ } 

如果所有項目的flex-grow屬性都為1,則它們將等分剩余空間(如果有的話)。如果一個項目的flex-grow屬性為2,其他項目都為1,則前者占據的剩余空間將比其他項多一倍。

4.3 flex-shrink屬性

flex-shrink屬性定義了項目的縮小比例,默認為1,即如果空間不足,該項目將縮小。


.item {flex-shrink: <number>; /* default 1 */ } 

如果所有項目的flex-shrink屬性都為1,當空間不足時,都將等比例縮小。如果一個項目的flex-shrink屬性為0,其他項目都為1,則空間不足時,前者不縮小。

負值對該屬性無效。

4.4 flex-basis屬性

flex-basis屬性定義了在分配多余空間之前,項目占據的主軸空間(main size)。瀏覽器根據這個屬性,計算主軸是否有多余空間。它的默認值為auto,即項目的本來大小。


.item {flex-basis: <length> | auto; /* default auto */ } 

它可以設為跟widthheight屬性一樣的值(比如350px),則項目將占據固定空間。

4.5 flex屬性

flex屬性是flex-grow,?flex-shrink?和?flex-basis的簡寫,默認值為0 1 auto。后兩個屬性可選。


.item {flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ] } 

該屬性有兩個快捷值:auto?(1 1 auto) 和 none (0 0 auto)。

建議優先使用這個屬性,而不是單獨寫三個分離的屬性,因為瀏覽器會推算相關值。

4.6 align-self屬性

align-self屬性允許單個項目有與其他項目不一樣的對齊方式,可覆蓋align-items屬性。默認值為auto,表示繼承父元素的align-items屬性,如果沒有父元素,則等同于stretch


.item {align-self: auto | flex-start | flex-end | center | baseline | stretch; } 

該屬性可能取6個值,除了auto,其他都與align-items屬性完全一致。

轉載于:https://www.cnblogs.com/hupan508/p/5189958.html

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

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

相關文章

SpiderMonkey-讓你的C++程序支持JavaScript腳本

譯序 有些網友對為什么D2JSP能執行JavaScript腳本程序感到奇怪&#xff0c;因此我翻譯了這篇文章&#xff0c;原文在這里。這篇教程手把手教你怎樣利用SpiderMonkey創建一個能執行JavaScript腳本的C程序&#xff0c;并讓JavaScript腳本操縱你的C程序的內部數據、操作。從這篇教…

Android 虛擬機學習總結Dalvik虛擬機介紹

1、Dalvik虛擬機與Java虛擬機的最顯著差別是它們分別具有不同的類文件格式以及指令集。Dalvik虛擬機使用的是dex&#xff08;Dalvik Executable&#xff09;格式的類文件&#xff0c;而Java虛擬機使用的是class格式的類文件。一個dex文件能夠包括若干個類。而一個class文件僅僅…

des vue 加密解密_vue DES 加密

ECB模式import cryptoJs from crypto-js// DES加密export const encryptDes (message, key) > {var keyHex cryptoJs.enc.Utf8.parse(key)var option { mode: cryptoJs.mode.ECB, padding: cryptoJs.pad.Pkcs7 }var encrypted cryptoJs.DES.encrypt(message, keyHex, op…

使用jQuery清空表單

$(#theform)[0].reset(); reset()這個函數的作用是將表單的值重置&#xff0c;變為默認值&#xff0c; 例&#xff1a; <input type"text" value"姓名"> 這個標簽的默認值就是”姓名“&#xff0c;如果使用上面的方法&#xff0c;就會重置為“姓名”…

MobX快速入門教程(重要概念講解)

轉載請注明原文地址&#xff1a;http://www.cnblogs.com/ygj0930/p/7372119.html 一&#xff1a;Mobx工作流程圖 二&#xff1a;MobX涉及到的概念 1:狀態state 組件中的數據。 2:被觀察observable 被observable修飾的state數據將會暴露給整個app&#xff0c;各觀察者組件都可以…

CentOS工作內容(七)禁用IPV6

CentOS工作內容&#xff08;七&#xff09;禁用IPV6 用到的快捷鍵 tab 自動補齊(有不知道的嗎) ctrla 移動到當前行的開頭(a ahead) ctrle 移動到當前行的開頭(e end) ctrlu 刪除(剪切)此處至開始所有內容 復制進來&#xff1a;按一下鼠標右鍵粘貼到SercureCRT 復制出去&#x…

循環結束后變回去 設置一個值_VBA掌握循環結構,包你效率提高500倍

這是系列免費教程《Excel VBA&#xff1a;辦公自動化》&#xff0c;還是老規矩&#xff0c;看看我們走到哪里了。1.認識VBA&#xff1a;什么是VBA&#xff1f;2.這些掌握了&#xff0c;你才敢說自己懂VBA3.VBA變量5年踩坑吐血精華總結4.VBA中重要的強制申明&#xff0c;誰看誰明…

連接到kali linux服務器上的MySQL服務器錯誤

前言&#xff1a;想把數據庫什么的都放在虛擬機kali Linux里&#xff0c;但無奈出了好多錯誤。 首先&#xff1a;可以參照上一篇文章開啟kali服務器端的遠程連接功能&#xff0c;上一篇文章 然后&#xff1a;使用window端的sqlyog&#xff08;MySQL圖形化連接工具&#xff09;連…

dedecms后臺怎么添加發布軟件?織夢后臺軟件內容管理

使用織夢cms有很多的功能&#xff0c;其中有一個是在dedecms后臺添加發布軟件&#xff0c;然后在前臺大家可以直接下載軟件&#xff0c;在織夢cms后臺怎么添加發布軟件呢&#xff1f;下面是織夢軟件內容管理的主要操作步驟。使用織夢cms有很多的功能&#xff0c;其中有一個是在…

301 302區別_如何正確理解301,302和canonial標簽

今天我們來學習一下幾個比較容易混淆的頁面跳轉標簽&#xff0c;301&#xff0c;302&#xff0c;relcanonial。在谷歌SEO里面&#xff0c;我們比較容易常見的是第一個301&#xff0c;302和canonial出現的比較少&#xff0c;但是不代表不存在&#xff0c;我會嘗試從以下價格方面…

ffmpeg文檔08-表達式計算/求值

8 表達式計算/求值 在計算表達式時&#xff0c;ffmpeg通過libavutil/eval.h接口調用內部計算器進行計算。 表達式可以包含一元運算符、運算符、常數和函數 兩個表達式expr1和expr2可以組合起來成為"expr1;expr2" &#xff0c;兩個表達式都會被計算&#xff0c;但是新…

為什么手機游戲手柄沒有流行起來?

問答社區知乎上有人提了一個問題&#xff0c;“為什么手機用游戲手柄沒有流行&#xff1f;” Ta找了不少論證&#xff1a;1&#xff09;手機用戶數量很大&#xff1b;2&#xff09;大量用戶在手機上花費最多時間的是玩游戲&#xff1b;3&#xff09;游戲機平臺&#xff08;的游…

c++排序算法ppt_C/C++學習教程:C語言排序算法—插入排序算法

前言&#xff1a;插入排序算法是所有排序方法中最簡單的一種算法&#xff0c;其主要的實現思想是將數據按照一定的順序一個一個的插入到有序的表中&#xff0c;最終得到的序列就是已經排序好的數據。直接插入排序是插入排序算法中的一種&#xff0c;采用的方法是&#xff1a;在…

python函數參數

1.位置參數 2.默認參數 指向參數為不可變對象 3.可變參數 **args 一個列表list或是元組tuple 4.關鍵字參數 **kw,是一個字典dict 5.命名關鍵字參數 *, 轉載于:https://www.cnblogs.com/aliy-pan/p/5198025.html

Python 常用函數 configparser模塊

使用ConfigParser模塊讀寫ini文件 ConfigParserPython的ConfigParser Module中定義了3個類對INI文件進行操作。分別是RawConfigParser、ConfigParser、SafeConfigParser。模塊所解析的ini配置文件是由多個section構成&#xff0c;每個section名用中括號‘[]’包含&#xff0c;每…

自制Unity小游戲TankHero-2D(3)開始玩起來

自制Unity小游戲TankHero-2D(3)開始玩起來 我在做這樣一個坦克游戲&#xff0c;是仿照&#xff08;http://game.kid.qq.com/a/20140221/028931.htm&#xff09;這個游戲制作的。僅為學習Unity之用。圖片大部分是自己畫的&#xff0c;少數是從網上搜來的。您可以到我的github頁…

mysql按月分列統計_實現mysql按月統計的教程

mysql有個字段是DATETIME類型&#xff0c;要實現可以按月統計&#xff0c;該怎么寫sql語句&#xff1f;select month(f1) from tt group by month(f1)or select DATE_FORMAT(f1,%m) from tt group by DATE_FORMAT(f1,%m)比如數據庫的為2008-01-15 12&#xff1a;10&#xff1a;…

Log4j的擴展-支持設置最大日志數量的DailyRollingFileAppender

Log4j現在已經被大家熟知了&#xff0c;所有細節都可以在網上查到&#xff0c;Log4j支持Appender&#xff0c;其中DailyRollingFileAppender是被經常用到的Appender之一。在討論今天的主題之前&#xff0c;我們先看下另外一個Appender。 最常用的Appender——RollingFileAppend…

VirtualBox虛擬機安裝CentOS 7

新建虛擬機 因為比較簡單&#xff0c;所以對于VirtualBox就不做過多介紹了&#xff0c;直接下載安裝即可&#xff0c;安裝好之后打開Oracle VM VirtualBox管理器&#xff0c;點擊新建&#xff0c;選擇Red Hat&#xff08;根據windows主機選擇 32/64 bit&#xff0c;通常會自動識…

mysql 指定賬戶已存在_安裝mysql時告訴我指定的賬戶已存在?

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里云數據庫專家保駕護航&#xff0c;為用戶…