久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

CSS3布局模式:伸縮布局盒(Flexbox)

CSS3布局模式:伸縮布局盒(Flexbox)HTML5中文學習網,是中國最大的HTML5中文門戶,為廣大HTML5愛好者提供各種HTML5資料,包括HTML5網站、HTML5資訊、HTML5應用、HTML5游戲、HTML5教程、HTML5視頻、

 

介紹

Flexbox(伸縮布局盒) 是 CSS3 中一個新的布局模式,為了現代網絡中更為復雜的網頁需求而設計。本文將介紹 Flexbox 語法的技術細節。瀏覽器的支持越來越快,所以當 Flexbox 被廣泛支持并應用時你將會快人一步。如果你想知道它是什么并是如何工作的,不妨仔細了解下吧!

 

為什么需要伸縮布局盒(Flexbox)?

作者長期以來使用表格、浮動、行內塊元素和其他 CSS 屬性來布局網站內容。然而,這些并不是為復雜的頁面和網頁應用而設計的。不管是簡單的垂直居中,還是靈活的網格布局都很難靠一己之力輕易實現,因此成就了 CSS 網格框架。但是,如果真的需要那么多項目來實現做這些事,為什么不讓它來的更簡單些呢?Flexbox 的目的就是改變這一切。

規范狀態和瀏覽器支持情況

Flexbox 規范的相關工作已經進展了3年。不同的瀏覽器也實現了不同的實驗版本。在2012年9月,Flexbox 語法的第三個主要修訂版本進入到候選推薦階段。這意味著 W3C 認為當前的語法是穩定的,并鼓勵瀏覽器開發商去實現它。

Flexbox 規范時間表:

  • 2009年7月 工作草案 (display: box;)
  • 2011年3月 工作草案 (display: flexbox;)
  • 2011年11月 工作草案 (display: flexbox;)
  • 2012年3月 工作草案 (display: flexbox;)
  • 2012年6月 工作草案 (display: flex;)
  • 2012年9月 候選推薦 (display: flex;)

Flexbox 已經被瀏覽器快速支持。Chrome 22+, Opera 12.1+, 和 Opera Mobile 12.1+ 已經支持了本文中所描述的 Flexbox。Firefox 18 和 Blackberry 10 也很快就會實現。我推薦大家使用已經支持的瀏覽器來閱讀本文和查看例子。

概念和術語

雖然現在我們可以使用 Flexbox 輕松創建布局,而不會像以前那樣難以理解,但我們仍然需要花一些時間去熟悉到底如何使用 Flexbox。新的術語和概念可能會是我們使用 Flexbox 時的一個障礙,所以讓我們先來了解以下它們。

Flexbox 由 伸縮容器 和 伸縮項目 組成。通過設置元素的 display 屬性為flexinline-flex可以得到一個伸縮容器。設置為flex的容器被渲染為一個塊級元素,而設置為inline-flex的容器則渲染為一個行內元素。

這里的示例創建了一個伸縮容器。

 

1234
.flex-container {
display: -webkit-flex;
display: flex;
}
view raw gistfile1.css This Gist brought to you by GitHub.

 

1234
.flex-container {
display: -webkit-flex;
display: flex;
}
view raw gistfile1.css This Gist brought to you by GitHub.

 

本文中所有的示例都會帶有相應的瀏覽器廠商前綴。

伸縮容器中的每一個子元素都是一個伸縮項目。伸縮項目可以是任意數量的。伸縮容器外和伸縮項目內的一切元素都不受影響。簡單地說,Flexbox 定義了伸縮容器內伸縮項目該如何布局。

Flex Lines 伸縮行

伸縮項目沿著伸縮容器內的一個 伸縮行 定位。通常每個伸縮容器只有一個伸縮行。

這個示例展示了2個項目在默認情況下的定位:沿著一個水平伸縮行從左至右顯示。

Writing Modes 書寫模式

在你設計 Flexbox 時的有一個重要的部分是更改伸縮行的方向。默認情況下,伸縮行和文本方向一致:從左至右,從上往下。

這是 W3C 關于一個名為書寫模式的新特性工作草稿。書寫模式是一個新的方法,讓你可以從右往左寫,甚至豎著寫,就像你知道的某些語言一樣。

書寫模式是一個正在進行的計劃,但是 Chrome 已經率先支持了directionCSS 屬性。如果我們在上一個例子中設置方向為rtl(從右往左) 那么不僅僅文字會從右往左書寫,而且 伸縮行也改變了方向,并更改了頁面的布局。

這也許就是 Flexbox 為什么如此抽象難懂的地方。當你正在制作一個語言不確定的頁面時你不能簡單的只是說“上”、“下”、“左”、“右”。

The Main Axis and the Cross Axis 主軸和側軸

為了描述抽象的書寫模式,Flexbox 使用 主軸 和 側軸的概念。伸縮行跟隨主軸。側軸則垂直于主軸。

起點、終點和各軸的方向的名稱如下:

  • 主軸起點 Main Start
  • 主軸終點 Main End
  • 主軸方向 Main Direction (有時候也成為伸縮流方向 Flow Direction)
  • 側軸起點 Cross Start
  • 側軸終點 Cross End
  • 側軸方向 Cross Direction

在繼續了解之前明白主軸和側軸是至關重要的。Flexbox 中的一切都和這些軸有關。在我們所有的例子中,書寫模式都是從左至右,從上到下,但是你需要記住并不是所有的 Flexbox 都是這樣的。

伸縮容器的屬性

flex-direction 伸縮流的方向

flex-direction允許你更改伸縮容器的主軸方向。flex-direction的默認值是row。該值表示伸縮項目根據書寫模式的方向布局。再次提醒,默認是從左至右,從上到下。其他的值如下:

  • row-reverse: 主軸起點和主軸終點交換。如果書寫模式是從左至右,伸縮項目則是從右往左顯示。
  • column: 主軸和側軸交換。如果書寫系統是垂直的,那么伸縮項目也是垂直顯示的。
  • column-reverse: 和 column 一樣,但是方向相反。

讓我們把前一個示例中的flex-direction改為column

現在我們的伸縮項目就是垂直顯示的了。

justify-content 主軸對齊

伸縮容器的justify-content屬性用于調整主軸上伸縮項目的位置。可能的值為:

  • flex-start (默認)
  • flex-end
  • center
  • space-between
  • space-around

這里我們設置justify-contentcenter讓伸縮項目在主軸上居中對齊:

flex-start,flex-end, 和center一看就懂。space-betweenspace-around則是分配伸縮項目之間空白空間的不同方法。這張規范中的圖示很好的解釋了一切:

align-items 側軸對齊

align-items是一個和justify-content相呼應的屬性。align-items調整伸縮項目在側軸上的定位方式。可能的值有:

  • flex-start (默認)
  • flex-end
  • center
  • baseline
  • stretch

這里我們設置align-itemscenter讓伸縮項目在側軸上居中對齊:

和之前一樣,flex-start,flex-end, 和center的意義顯而易見。stretch也很簡單:它會將伸縮項目從側軸起點拉伸到側軸終點。baseline則是讓伸縮項目與它們的基線對齊。基線根據伸縮項目的內容計算得到。下面這張來自W3C標準的圖例很好的解釋了這些屬性:

flex-wrap 伸縮行換行

目前為止,每個伸縮容器都有且只有一個伸縮行。使用flex-wrap你可以為伸縮容器創建多個伸縮行。這個屬性接受以下值:

  • nowrap (默認)
  • wrap
  • wrap-reverse

如果flex-wrap設置為wrap,在一個伸縮行容不下所有伸縮項目時,伸縮項目會換行到一條新增的伸縮行上。新增的伸縮行根據側軸的方向添加。

我們使用flex-wrap來看個例子:

wrap-reverse和 wrap 一樣,只是新的伸縮行會被添加到側軸的反方向上。

align-content 堆棧伸縮行

align-content會更改flex-wrap的行為。它和align-items相似,但是不是對齊伸縮項目,它對齊的是伸縮行。可能你已經想到了,它接受的值也很相似

  • stretch (默認)
  • flex-start
  • flex-end
  • center
  • space-between
  • space-around

這些值與justify-contentalign-items中的值一樣。

在這個例子中,我們設置align-contentcenter

flex-flow 伸縮方向與換行

flex-flowflex-directionflex-wrap的縮寫。

flex-flow: [flex-direction] [flex-wrap]

舉個例子:

 

1234
.flex-container {
-webkit-flex-flow: column nowrap;
flex-flow: column nowrap;
}
view raw gistfile1.css This Gist brought to you by GitHub.

 

1234
.flex-container {
-webkit-flex-flow: column nowrap;
flex-flow: column nowrap;
}
view raw gistfile1.css This Gist brought to you by GitHub.

 

伸縮項目的屬性

一個伸縮項目是一個伸縮容器的子元素。伸縮容器中的文本也被視為一個伸縮項目。

伸縮項目中內容與普通流一樣。舉例來說,當一個伸縮項目被設置為浮動,你依然可以在這個伸縮項目中放置一個浮動元素。

伸縮項目都有一個 主軸長度(Main Size) 和一個 側軸長度(Cross Size)。主軸長度是伸縮項目在主軸上的尺寸。側軸長度是伸縮項目在側軸上的尺寸。或者說,一個伸縮項目的寬或高取決于伸縮容器的軸,可能就是它的主軸長度或側軸長度。

下面的屬性可以調整伸縮項目的行為:

order 顯示順序

order是最簡單明了的屬性。設置伸縮項目的 order 可以調整它們渲染時的順序。在這個例子中,我們設置其中一個伸縮項目的order為 -1,于是它被提前到了其他伸縮項目的最前面。

如果需要文檔順序和顯示順序不同時,這就是個很有用的功能了。

margin 外邊距

你應該對margin: auto;這種用法很熟悉。在伸縮盒中,它也能做同樣的事情,但是更加強大。一個 "auto" 的 margin 會合并剩余的空間。它可以用來把伸縮項目擠到其他位置。

這里我們在第一個伸縮項目上聲明了margin-right: auto;,導致了所有的剩余空間被合并到那個元素的右邊去了:

這里我們使用margin: auto;來重現經典CSS布局中的圣杯:真·垂直居中:

align-self 側軸對齊

伸縮項目的align-self屬性會覆蓋該項目的伸縮容器的align-items屬性。它的值和align-items一樣:

  • stretch (默認)
  • flex-start
  • flex-end
  • center
  • baseline

在這個例子中我們為每個伸縮項目應用了不同的align-self值:

我在例子中包含了2個基線對齊的伸縮項目,因為它們的對齊需要互相作用。

flex 伸縮性

現在我們終于要開始設置伸縮盒的伸縮性了。flex指定了一個伸縮項目該如何分配主軸上的剩余空間。

讓我們一次把所有的常見值都看一遍吧。

flex: [number]

這個語法指定了一個數字,代表了這個伸縮項目該占用的剩余空間比例。

在這個例子中,第一個伸縮項目占用了 2/4 的剩余空間,而另外兩個各占用了 1/4 的剩余空間。

如果把每個伸縮項目都設置為 1 的話,那么剩余空間就會被平均分配了。

flex: initial

一個flex屬性值被設為initial的伸縮項目,在有剩余空間的情況下不會有任何變化,但是在必要的情況下會被收縮。

flex: auto

一個flex屬性值被設為auto的伸縮項目,會根據主軸自動伸縮以占用所有剩余空間。

auto目前僅在 Opera 12.11 尚有效,在 Chrome 23.0.1271.95 上無效。你可以通過使用flex: 1;來達到一樣的效果。

flex: none

一個flex屬性值被設為none的伸縮項目,在任何情況都不會發生伸縮。

flex 縮寫

flex也可以把flex-grow,flex-shrink, 和flex-basis這3個縮寫為1個聲明:

flex: [flex-grow] [flex-shrink] [flex-basis]

大多數情況下沒必要使用這種語法。另外,它需要一個更容易理解的伸縮算法。如果你覺得自己挺厲害的,到規范里看一下吧。

當然你也可以將flex-grow,flex-shrink, 和flex-basis作為單個屬性分開來設置。但我強烈反對這種方式:當使用flex縮寫時,即使沒有某些值沒有設置也能獲得更合理的默認值。

visibility 疊加項目

當該值生效時,應用visibility: collapse;visibility: hidden;display: none;的效果是不一樣的。如果是collapse,該元素會影響伸縮容器的側軸長度,但不會被現實或占用主軸的空間。如果你想動態添加或移除伸縮項目又不會影響伸縮容器的側軸長度,這將會非常有用。

目前為止,visibility: collapse;還沒有被讓任何瀏覽器正確的實現。現在visibility: collapse;還和visibility: hidden;實現著一樣的效果。我希望能盡快得到改觀。

你可以在 這里 看到collapse應該是如何工作的。

總結

如你所見,伸縮布局盒(Flexbox) 是一個強大的新型布局模式,將會給網站帶來革命性的布局方法,但它也需要一種全新的思考方式。希望這篇文章能為你使用伸縮布局盒構建網站帶來幫助。我不知道你怎么想,但是在我看來未來是美好的。

原文:Dive into Flexbox (http://weblog.bocoup.com/dive-into-flexbox)
參考資料:Css3-flexbox (http://www.w3.org/html/ig/zh/wiki/Css3-flexbox)

轉自:[譯]深入了解 Flexbox 伸縮盒模型http://c7sky.com/dive-into-flexbox.html

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

主站蜘蛛池模板: 国产91色| 91调教打屁股xxxx网站 | 国产区一区| 久久怡红院 | www.99riav| 伊人免费视频 | 正在播放国产精品 | 激情久久五月天 | 欧美在线播放视频 | 欧美一区二区三区在线视频 | 中文字幕在线资源 | av手机在线免费观看 | 久久观看 | 精品国产一二三 | 欧美偷拍视频 | 成人欧美激情 | 精品视频在线观看免费 | 六月婷婷综合 | 成人免费毛片片v | 无毒不卡| 午夜在线观看免费视频 | 69人人| 黄色片视频网站 | 91手机在线视频 | 亚洲v视频 | 国产一级在线观看 | 黄色国产 | 日韩大片在线观看 | 黄色片视频网站 | 一区二区网站 | 亚洲成在线 | 精品黄色 | 三级a毛片 | 久久久亚洲精品视频 | 亚洲精品一区二区三区在线观看 | 在线一区视频 | 国内精品一区二区三区 | 国产1级片| 亚洲激情欧美 | 色婷婷精品国产一区二区三区 | 欧美精品一级片 |