摘要:本文記錄了我在學習前端上的筆記,方便以后的復習和鞏固。注意項目現在顯示的寬度是他們的默認寬度。各行將會伸展以占用剩余的空間。在其它情況下,剩余空間被所有行平分,擴大各行的側軸尺寸。這不會影響源代碼。不要忘記了,默認情況下,項目的值為。
開始使用Flex本文記錄了我在學習前端上的筆記,方便以后的復習和鞏固。
在父元素中的顯式的設置display:flex或者display:inline-flex
/* 聲明父元素為flex容器 */ ul{ display: flex; /* 或者inline-flex */ }
效果如下圖:
默認情況下,div在css中是垂直的,如下圖:
Flex容器屬性關鍵詞:
Flex容器(Flex Container):父元素顯式設置了display:flex
Flex項目(Flex Items):Flex容器內的子元素
flex-direction || flex-wrap || flex-flow || justify-content || align-items || align-contentflex-direction
flex-dirction屬性控制Flex項目沿主軸(Main Axis)的排列方向。
flex-direction屬性可以讓你決定Flex項目如何排列。它可以是行(水平)、列(垂直)或者行列相反的方向。
它具有四個值:
/* ul是一個flex容器 */ ul{ flex-direction: row || column || row-reverse || column-reverse; }
主軸和側軸: 主軸可以當成當成水平方向理解,側軸則是垂直方向。Main-Axis就是水平方向,從左到右,這也是默認方向。Cross-Axis是垂直方向,從上往下。
默認情況下,flex-direction屬性的值是row。它讓Flex項目沿著Main-Axis排列(從左到右,水平排列)
如果把flex-direction屬性的值改成column,這時Flex項目將沿著Cross-Axis從上到下垂直排列。不在是從左到右水平排列。
如果把flex-direction屬性的值加上reverse如
ul{ flex-direction: row-reverse; }
如下圖:
ul{ flex-direction: column-reverse; }
如下圖:
flex-wrapflex-wrap屬性有三個屬性值:
ul{ flex-wrap: warp || nowrap || wrap-reverse; }
flex-wrap默認屬性是nowrap。也就是說,Flex項目在Flex容器內不換行排列。
ul{ flex-wrap: nowarp;/* Flex容器內的Flex項目不換行排列 */ }
當你希望Flex容器內的Flex項目達到一定數量時,能換行排列。當Flex容器中沒有足夠的空間放置Flex項目(Flex項目默認寬度),那么Flex項目將會換行排列。把它(flex-wrap)的值設置為wrap就有這種可能:
ul{ flex-wrap: wrap; }
現在Flex項目在Flex容器中就會多行排列。
在這種情況下,當一行再不能包含所有列表項的默認寬度,他們就會多行排列。即使調整瀏覽器大小。
注意:Flex項目現在顯示的寬度是他們的默認寬度。也沒有必要強迫一行有多少個Flex項目。
flex-wrap還有一個值:warp-reverse它讓Flex項目在容器中多行排列,只是方向是反的
flex-flowflex-flow是flex-direction和flex-wrap兩個屬性的速記屬性。
就像border一樣
ul{ border:1px solid #ccc; flex-flow: row wrap; /* 第一個值是flex-flow的值第二個則是flex-direvtion的值 */ }justify-content
justify-content屬性可以接受下面五個值之一
ul{ justify-content: flex-start || flex-end || center || space-between || space-around }
justify-content屬性主要定義了Flex項目在Main-Axis上的對齊方式。你可以想象下text-align屬性。
各個屬性的效果如圖:
這兩個屬性值可以一起理解
flex-start讓所有Flex項目靠Main-Axis開始邊緣(左對齊)
flex-end讓所有Flex項目靠Main-Axis結束邊緣(右對齊)
center讓所有Flex項目排在Main-Axis中間(居中對齊)
space-between讓除了第一個和最一個Flex項目的兩者間間距相同(兩端對齊)
space-around讓每個Flex項目具有相同的空間。
align-items屬性可以接受這些屬性值
ul{ align-items: flex-start || flex-end || center || stretch || baseline }
它主要用來控制Flex項目在Cross-Axis垂直方向的對齊方式。這也是align-items和justify-content兩個屬性之間的不同之處。
flex-start/baseline:伸縮項目在側軸起點邊的外邊距緊靠住該行在側軸起點的邊。
flex-end:伸縮項目在側軸終點邊的外邊距靠住該行在側軸終點的邊。
center:伸縮項目的外邊距盒在該行的側軸上居中放置。(如果伸縮行的尺寸小于伸縮項目,則伸縮項目會向兩個方向溢出相同的量)。
stretch:伸縮項目拉伸,填滿整個側軸
flex-start:各行向伸縮容器的起點位置堆疊。伸縮容器中第一行在側軸起點的邊會緊靠住伸縮容器在側軸起點的邊,之后的每一行都緊靠住前面一行。
flex-end:各行向伸縮容器的結束位置堆疊。伸縮容器中最后一行在側軸終點的邊會緊靠住該伸縮容器在側軸終點的邊,之前的每一行都緊靠住后面一行。
center:各行向伸縮容器的中間位置堆疊。各行兩兩緊靠住同時在伸縮容器中居中對齊,保持伸縮容器在側軸起點邊的內容邊和第一行之間的距離與該容器在側軸終點邊的內容邊與第最后一行之間的距離相等。(如果剩下的空間是負數,則行的堆疊會向兩個方向溢出的相等距離。)
space-between:各行在伸縮容器中平均分布。如果剩余的空間是負數或伸縮容器中只有一行,該值等效于「flex-start」。在其它情況下,第一行在側軸起點的邊會緊靠住伸縮容器在側軸起點邊的內容邊,最后一行在側軸終點的邊會緊靠住伸縮容器在側軸終點的內容邊,剩余的行在保持兩兩之間的空間相等的狀況下排列。
space-around:各行在伸縮容器中平均分布,在兩邊各有一半的空間。如果剩余的空間是負數或伸縮容器中只有一行,該值等效于「center」。在其它情況下,各行會在保持兩兩之間的空間相等,同時第一行前面及最后一行后面的空間是其他空間的一半的狀況下排列。
stretch:各行將會伸展以占用剩余的空間。如果剩余的空間是負數,該值等效于「flex-start」。在其它情況下,剩余空間被所有行平分,擴大各行的側軸尺寸。
Flex項目屬性order || flex-grow || flex-shrink || flex-basis orderoredr
允許Flex項目在一個Flex容器中重新排序。基本上,你可以改變Flex項目的順序,從一個位置移動到另一個地方。
這不會影響源代碼。這也意味著Flex項目的位置在HTML源代碼中不需要改變。order屬性的默認值是0。它可以接受一個正值,也可以接受一個負值。
值得注意的是,Flex項目會根據order值重新排序。從底到高。
默認情況下,所有Flex項目的order值都是0。把前面給列表的樣式運用過來。看到的效果如下:
Flex項目顯示是按HTML源代碼中的順序來顯示,Flex項目1、2、3和4。
li:nth-child(1){ order:1 }
Flex項目就重新進行了排列,從低到高排列。不要忘記了,默認情況下,Flex項目2、3、4的order值為0。現在Flex項目1的order值為1
Flex項目2、3和4的order值都是0。HTML源代碼秩序并沒有修改過。如果給Flex項目2的order設置為2呢?
是的,你猜對了。它也增加堆棧。現在代表Flex項目的最高的order值。
flex-grow和flex-shrinkflex-grow和flex-shrink屬性控制Flex項目在容器有多余的空間如何放大,在沒有額外空間又如何縮小
它們可以接受0或大于0的任何正數
值為0
值為1
看下圖會更好理解
flex-shrink值為0時他們不會縮小會保持原來的大小
flex-basis注意:負數無效
這個屬性和width,height屬性相同,用來指定flex項目的大小
屬性值:
.flex-item{ flex-bassis: auto ||; }
flex-basis指定了第四個flex項目的初始尺寸。
默認值: auto
flex這個屬性是flex-grow、flex-shrink和flex-basis的速寫。
.flex-item{ flex: none | auto | [? || ]; }
默認值: 0 ,1, auto
align-self使用align-self屬性可以指定flex項目自身的對齊方式或者使用align-items來指定單個flex項目。使用align-items對齊方式來解釋flex容器,能更好的理解他們的值。
.flex-item{ align-self: auto | flex-start | flex-end | center | baseline | stretch; }
第三個和第四個flex項目使用align-self屬性覆蓋了其默認的對齊方式。
默認值: auto
注意: align-self取值為auto值時,flex項目對齊方式會根據其父元素align-items來決定。如果其元素設置為stretch值時或沒有父元素時,align-self的值為auto時將無對齊方式一說。著作權歸作者所有。
最后,如有錯誤和疑惑請指出,多謝各位大哥
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/111835.html
摘要:注本文首發于個人博客學習筆記。最近看了下變量,又名自定義屬性,跟大家分享一下我的學習筆記。使用自定義屬性來設置變量名,并使用特定的來訪問。二學習筆記聲明調用聲明方式變量聲明的方式非常簡單,如下,聲明了一個名叫的變量。 注:本文首發于個人博客 《CSS Variables學習筆記》。 最近看了下CSS Variables(CSS變量,又名CSS自定義屬性),跟大家分享一下我的學習筆記。 ...
摘要:布局經典問題初步整理標簽前端本文主要對布局中常見的經典問題進行簡單說明,并提供相關解決方案的參考鏈接,涉及到三欄式布局,負,清除浮動,居中布局,響應式設計,布局,等等。 CSS 布局經典問題初步整理 標簽 : 前端 [TOC] 本文主要對 CSS 布局中常見的經典問題進行簡單說明,并提供相關解決方案的參考鏈接,涉及到三欄式布局,負 margin,清除浮動,居中布局,響應式設計,Fl...
摘要:你可以用網格這樣做這樣的顯示效果是沒什么錯誤的,當使用網格,重新定義列數非常簡單。絕對定位當我們絕對定位一個網格元素的時候,這個元素會跑到它的容器中,我們可以用和來定位它。最簡單的命名約定使用網格自動編號。 注:此文是我翻譯的第一篇技術文章。適合有一定CSS原生網格布局使用經驗的開發者(讀前需要先去了解一下原生CSS網格的語法),原生CSS網格布局(Native CSS grid)截止...
閱讀 2434·2021-11-18 10:02
閱讀 693·2021-10-08 10:04
閱讀 2263·2021-09-03 10:51
閱讀 3549·2019-08-30 15:44
閱讀 2806·2019-08-29 14:09
閱讀 2471·2019-08-29 12:21
閱讀 2068·2019-08-26 13:45
閱讀 1810·2019-08-26 13:25