国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

一篇帶給你關(guān)于Flex的一切

開發(fā) 前端
flex 是一種布局方式,在 CSS3 之后開始有。它主要由父容器和子項組成。

flex 是一種布局方式,在 CSS3 之后開始有。它主要由父容器和子項組成,父容器有六個屬性,分別為:

  • 控制主軸軸向:flex-direction row:橫軸(默認)row-reverse:倒過來的橫軸column:豎軸column-reverse:倒過來的豎軸。
  • 換行方式:flex-wrap nowrap:不換行(默認)wrap:換行wrap-reverse:反著換行。
  • 主軸排列:justify-content。
  • 交叉軸排列:align-items。
  • 軸向與換行組合設(shè)置:flex-flow(流向) 一般很少用這個屬性,即改變子項的布局順序,正著來,倒著來。

子項也有六個屬性,分別為:

  • 彈性擴展:flex-grow 指定容器剩余空間多余時的分配規(guī)則默認值為 0,多余空間不分配。
  • 彈性收縮:flex-shrink 指定容器剩余空間不足時的分配規(guī)則默認值為 1,空間不足要分配;如果為 0,表示不分配。
  • 基礎(chǔ)尺寸:flex-basis 指定 flex 元素在主軸方向上的初始大小(基礎(chǔ)尺寸)默認值為 auto,即項目本身大小
  • 縮寫:flex flex-grow、flex-shrink、flex-basis 的縮寫默認值為 0 1 auto。
  • 主軸順序:order。
  • 交叉軸對齊方式:align-self。

總的來說,父容器控制整體布局,子項控制子項布局。

在面試中,常常不會問怎么寬泛,最常見的 flex 面試題為:

  • flex: 0 1 auto 怎么理解?
  • flex: 1具體代表什么,有什么應用場景。
  • flex: 0、flex: 1、flex: none、flex: auto,表示什么意思,并應用在什么場景下使用?

要想回答這些問題,我們必須了解子項中的 flex 屬性。

flex 語法

flex: none | auto | [< 'flex-grow' > < 'flex-shrink' >? || < 'flex-basis' > ];

單管道符 | ,表示排他。也就是這個符號前后的屬性值都是支持的,且不能同時出現(xiàn)。因此,下面這些語法都是支持的:

flex: auto;
flex: none;
flex: [< 'flex-grow' > < 'flex-shrink' >? || < 'flex-basis' >];

方括號 [...] 表示范圍。支持的屬性在這個范圍內(nèi)。

其中 ? ,表示 0 個或者 1 個,也就是說 flex-shrink 屬性可有可無。因為 flex 屬性值也可以是 2 個值。

flex: auto;
flex: none;
/* 2個值 */
flex: 1 100px;
/* 3個值 */
flex: 1 1 100px;

雙管道 || ,表示”或者“的意思。表示前后可以分開獨立使用,也就是 flex: flex-grow flex-shrink? 和 flex-basis 都是合法的。于是我們又多了 2 種合法的寫法:

/* 1個值,flex-basis */
flex: 100px;
/* 2個值,flex-grow 和 flex-shrink */
flex: 1 1;

轉(zhuǎn)為文字表述

單值語法:

如果 flex 的屬性值只有一個值,有三種情況:

  • 一個無單位數(shù),例如例如 flex: 1,表示 flex-shrink: 1,剩余空間擴展。此時,flex-shrink 和 flex-basis 的值分別是 1 和 0%。注意,這里的 flex-basis 的值是 0%,而不是默認值 auto 只要改變 flex: 數(shù)字,flex-basis 的值就為 0。
  • 一個有效的寬度(width)值,表現(xiàn)形式為長度值,例如 flex: 100px,表示flex-basis: 100px,基礎(chǔ)尺寸為 100px。此時,flex-grow 和 flex-shrink 的值都是 1,注意,這里的 flex-grow 的值是 1,而不是默認值 0。
  • 關(guān)鍵字 none,auto 或 initial。

雙值語法:

如果 flex 的屬性值有兩個值,則第 1 個值一定是 flex-grow,第 2 個根據(jù)值的類型不同表示不同的 CSS 屬性,具體規(guī)則如下:

  • 數(shù)值:例如flex: 1 2,則這個 2 表示 flex-shrink,此時 flex-basis 的值為 0%,而非默認值 auto。
  • 長度值,例如flex: 1 100px,則這個 100px 值 flex-basis,此時 flex-shrink 默認值為 0。

三值語法:

如果 flex 的屬性值有 3 個值,則長度值表示 flex-basis,其余 2 個數(shù)值分別表示flex-grow 和 flex-shrink。下面兩行 CSS 語句的語法都是合法的,且含義也是一樣的:

flex: 1 2 50%;
flex: 50% 1 2;

flex 屬性值場景應用

flex 默認值為 0 1 auto。除此之外,還有各種其他值:

  • flex: none,等同于 flex: 0 0 auto。
  • flex: auto,等同于 flex: 1 1 auto。
  • flex: 1,等同于 flex: 1 1 0%。
  • flex: 0,等同于 flex 0 1 0%。

張鑫旭大神畫過一張圖:

單值語法 等同于 備注 flex: initial flex: 0 1 auto 初始值,常用 flex: 0 flex: 0 1 0% 適用場景少 flex: none flex: 0 0 auto 推薦 flex: 1 flex: 1 1 0% 推薦 flex: auto flex: 1 1 auto 適用場景少。

默認值 flex: initial

它等同于 flex:0 1 auto,表示 flex 容器有剩余空間時尺寸不增長(flex-grow: 0),flex 容器尺寸不足時尺寸會收縮變小(flex-shrink:1),尺寸自適應于內(nèi)容(flex-basis:auto)。

我的理解:子項總長度小于總?cè)萜鲿r,不會去撐滿(flex-grow:0),而按實際寬高度存在(flex-basis:auto);當子項總長度大于總?cè)萜鲿r,子項會相對于的收縮相對比例(flex-shrink:1)。

適用場景

適用于子項總長度小于總?cè)萜鞯膱鼍埃绨粹o、標題、小圖標等小部件的排版布局。

flex: 0 和 flex: none 的區(qū)別

  • flex: 0 等同于設(shè)置 flex: 0 1 0%,flex:none 等同于 flex: 0 0 auto。
  • flex: 0,因為是一個值且為數(shù)值,所以它表示 flex-grow,后續(xù)我發(fā)現(xiàn)只用設(shè)置了flex: 數(shù)字,那么 flex-basis 就自動成了 0%,所以,設(shè)置flex:0 的元素的最終尺寸表示為最小內(nèi)容寬度。

注意:

  • flex: 1 === flex: 1 1 0%。
  • flex: 0 === flex: 0 1 0%。
  • flex 設(shè)置為數(shù)字后,雖然 flex-basis 為最小寬度,但是前者的 flex-grow 有值,可以把子項擴充滿容器,后者為 0,不擴展。

flex: none,既不是數(shù)值也不是長度值,none 關(guān)鍵字。flex: 0 0 auto 表示元素尺寸不會收縮也不會擴展,再加上 flex-basis: auto 表示固定尺寸由內(nèi)容決定,由于元素不具有彈性,因為,元素內(nèi)的元素不會換行,最終尺寸通常表現(xiàn)為最大內(nèi)容寬度。

適用使用 flex: 0 的場景

flex:0的應用場景。

無論文字的內(nèi)容給如何設(shè)置,左側(cè)內(nèi)容的寬度都是圖像的寬度。

適合使用 flex: none 的場景

當 flex 子項的寬度就是內(nèi)容的寬度,且內(nèi)容永遠不會換行,則適合使用 flex:none,例如如下的場景,圖片和按鈕固定長度,內(nèi)容彈性。

flex:none適用場景。

flex: 1 和 flex: auto 的區(qū)別和適用場景

flex:1 等同于設(shè)置 flex: 1 1 0% ,flex: auto 等同于 flex: 1 1 auto。

可以看出兩者的 flex-grow 和 flex-shrink 都是一樣的,意味著它們都可以彈性擴展以及彈性收縮,區(qū)別在于 flex: 1 中 flex-basis 為 0,即寬度為 0。flex:auto 中的 flex-basis為 auto,即寬度為自身寬度。

表現(xiàn)的樣子為:

flex:1。

這里需要解釋一下,因為我最開始也不理解,其公式為:

每個子項的寬度 = (總寬度 - flex-basis 的寬度)/ 3(以這個例子為例)。

因為 flex:1 的 flex-basis 的寬度為 0 ,所以最后它的總寬度擴張或者收縮時每個子項都能等分。

適用于 flex: 1 的場景

當希望元素充分利用剩余空間,同時不會侵占其他元素應用的寬度的適用,適合適用 flex:1,例如所有的等分列表。

之前適用 flex: none 的例子,同樣設(shè)置文字部分flex: 1 也能實現(xiàn)類似的效果。

flex:1。

適用于 flex: auto 的場景

當希望元素充分利用剩余空間,但是各自的尺寸按照各自內(nèi)容進行分配的時候,適用于 flex: auto。

例如導航數(shù)量不固定,每個導航文字數(shù)量頁不固定的導航效果就適合適用 flex: auto。

flex-auto。

回過頭來看之前說的面試題

  1. flex: 0 1 auto 怎么理解?
  2. flex: 1具體代表什么,有什么應用場景。
  3. flex: 0、flex: 1、flex: none、flex: auto,表示什么意思,并應用在什么場景下使用?

第一個問題回答。

flex 的默認值為 0 1 auto,表示容器剩余空間有多余的時候不擴展,不足的時候收縮,子項的寬度根據(jù)自身的寬度來展示。

第二個問題回答。

腦子思考 flex 的值如果是一個值且為數(shù)字,說明是 flex-grow:1,當它為數(shù)字時,flex-basis 會自動變成 0,所以它具體表示為 flex:1 1 0%,表示容器剩余空間有多余的時候擴展,不足的時候收縮,子項的寬度為 0。它一般適用于充分利用剩余空間,又不侵占其他元素的寬度,例如等分布局。

第三個問題回答。

flex:0,表示 flex: 0 1 0%,表示容器剩余空間有多余的時候不擴展,不足的時候收縮,子項的寬度為 0,適用設(shè)置在替換元素的父元素上。

flex:1,看第二個回答。

flex: none,表示 flex: 0 0 auto,表示容器剩余空間有多余的時候不擴展,不足的時候也不收縮,子項的寬度為自身寬度,適用于不換行的內(nèi)容或者較少的小控件元素上。

flex: auto,表示 flex: 1 1 auto,表示容器剩余空間有多余的時候擴展,不足的時候收縮,子項的寬度為自身寬度,適用于基于內(nèi)容動態(tài)適配的布局(例如導航數(shù)量文字長度不固定)。

flex:initial,表示 flex: 0 1 auto,表示容器剩余空間有多余的時候不擴展,不足的時候收縮,子項的寬度為自身寬度,適用于小控件元素的分布布局,或者某一項內(nèi)容動態(tài)變化的布局。

參考資料

  • flex:0 flex:1 flex:none flex:auto 應該在什么場景下使用?
  • CSS flex 屬性深入理解。
  • MDN Web Docs flex。
  • 一勞永逸的搞定 flex 布局。
責任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2021-07-12 06:11:14

SkyWalking 儀表板UI篇

2021-07-08 07:30:13

Webpack 前端Tree shakin

2023-03-13 09:31:04

2021-04-14 07:55:45

Swift 協(xié)議Protocol

2022-02-25 15:50:05

OpenHarmonToggle組件鴻蒙

2021-04-23 08:59:35

ClickHouse集群搭建數(shù)據(jù)庫

2021-05-08 08:36:40

ObjectString前端

2021-10-28 08:51:53

GPIO軟件框架 Linux

2022-04-29 14:38:49

class文件結(jié)構(gòu)分析

2021-04-01 10:51:55

MySQL鎖機制數(shù)據(jù)庫

2021-04-08 11:00:56

CountDownLaJava進階開發(fā)

2021-03-12 09:21:31

MySQL數(shù)據(jù)庫邏輯架構(gòu)

2022-02-17 08:53:38

ElasticSea集群部署

2021-01-28 08:55:48

Elasticsear數(shù)據(jù)庫數(shù)據(jù)存儲

2022-03-22 09:09:17

HookReact前端

2024-06-13 08:34:48

2021-07-21 09:48:20

etcd-wal模塊解析數(shù)據(jù)庫

2021-06-21 14:36:46

Vite 前端工程化工具

2021-04-14 14:16:58

HttpHttp協(xié)議網(wǎng)絡(luò)協(xié)議

2023-03-29 07:45:58

VS編輯區(qū)編程工具
點贊
收藏

51CTO技術(shù)棧公眾號

四虎影视永久免费在线观看一区二区三区 | 欧美第一视频| 国产精品亚洲一区二区三区妖精 | 在线视频观看一区| 91在线中字| 国产一区二区三区日韩欧美| 你懂的在线观看一区二区| 国产精品免费久久久| 亚洲国产网站| 日本福利视频在线观看| 国产精品美女久久久久高潮| 你懂的视频在线| 亚洲风情亚aⅴ在线发布| www.一区| 国产欧美日韩丝袜精品一区| 日本va欧美va瓶| www.色偷偷.com| 欧美性少妇18aaaa视频| www亚洲人| 亚洲国产一区自拍| 精品国产18久久久久久洗澡| 国产偷久久久精品专区| 国产成人综合亚洲91猫咪| 成人午夜影院| 精品日韩一区二区三区免费视频| 久久激情av| 国产无遮挡又黄又爽免费软件| 欧美日韩夫妻久久| 日韩欧美2区| 亚洲sss综合天堂久久| 精品无人码麻豆乱码1区2区 | 国产视频在线一区二区| 国产精品香蕉| 91传媒视频在线观看| 风间由美一区二区三区在线观看| 中文字幕理伦片免费看| 日韩风俗一区 二区| 欧美精品一区二区久久| 成人免费在线网| 欧美丰满少妇xxxxx高潮对白| 中文字幕一精品亚洲无线一区 | 就去色蜜桃综合| 国产日韩在线不卡| 免费在线你懂的| 日本韩国在线不卡| 久久av资源网| 亚洲日本一区二区三区在线观看| 精品精品国产国产自在线| 99国产精品视频免费观看一公开| 99免费视频观看| 亚洲的天堂在线中文字幕| 精品一区二区在线视频| 国产精品久久久久久妇女| 久99久视频| 自拍偷自拍亚洲精品播放| 五月天av在线| 成人av资源网| 欧美国产综合一区二区| 亚洲欧洲日本韩国| 国产日韩欧美在线看| 欧美天天综合网| 欧美**字幕| 337p粉嫩大胆噜噜噜鲁| 亚洲激情第一页| 久久综合九色综合97婷婷女人| 丁香花在线影院| 成人av在线网址| 国产精品美女一区二区三区| 99精品电影| 色乱码一区二区三区在线| 在线日韩av观看| 久久精品男女| 欧美3p视频在线观看| 日本在线播放不卡| 欧洲av在线精品| 国产一区二区三区综合| 青春草视频在线观看| 成人久久一区二区三区| 亚洲高清福利视频| 国产精品国产三级国产aⅴ入口| 国产成人午夜性a一级毛片| 成人免费在线观看网站| 欧美肥婆姓交大片| h动漫在线视频| 国产精品人成电影在线观看| 日韩亚洲欧美一区| 中文字幕一区二区三区乱码图片| 日本福利片免费看| 2025国产精品视频| 欧美国产精品中文字幕| 久久精品 人人爱| 中文在线√天堂| 国产日韩欧美91| 亚洲国产天堂久久国产91| 亚洲精品免费在线观看| 免费福利视频一区| 激情在线小视频| 精品日本一区二区三区在线观看| 欧美午夜在线观看| 99久久国产综合精品女不卡| 欧美精品总汇| av动漫在线播放| 国产日韩欧美日韩| 久久视频在线看| 91在线精品秘密一区二区| 欧美黄色免费| 午夜在线视频播放| 精品久久精品久久| 久久久久国产精品www| 亚洲精品免费一二三区| 狠狠色狠狠色综合日日91app| 日本久久黄色| 人人做人人爽| 国产精品夜夜夜爽张柏芝| 国产一区二区激情| 91搞黄在线观看| 美女一区二区久久| 中文字幕在线直播| 你懂的在线播放| 三级短视频在线| 日日摸日日碰夜夜爽无码| 欧美日韩成人免费| 亚洲人成网站精品片在线观看| 欧美精品一二| 久久天天久久| 性欧美高清come| 成人午夜免费在线视频| 欧美高清激情视频| 欧美精品一区二区高清在线观看 | 自拍视频一区二区三区| 一区二区在线免费视频| 欧美性猛交xxxxxx富婆| 国产精品久久久久久久久久久免费看| 久久99国产精品麻豆| 国产亚洲午夜| 日本免费久久| 超碰在线caoporen| 国产二区视频在线| 欧美亚洲日本黄色| www.日韩.com| 亚洲综合区在线| 亚洲精品乱码| 婷婷综合亚洲| 色婷婷一区二区三区| 久久综合社区| 欧美性www| 在线观看国产视频一二三| jizzjizzxxxx| 日韩av一二三四区| 国产精品久久久久久久一区探花| 久久av中文字幕| 一区二区三区国产视频| 日韩av在线免费播放| 欧美tickling挠脚心丨vk| 欧美一区二区视频在线观看| 99久久国产综合精品色伊| 精品在线观看视频| 欧美在线综合| 亚洲免费黄色| 国产亚洲激情| 久久精品免费| 裸体一区二区三区| 天天躁日日躁狠狠躁欧美| 欧美人xxx| 91激情在线| 日本精品久久久久中文字幕| 91视频88av| 中文字幕亚洲欧美一区二区三区| 亚洲精品永久免费精品| 亚洲欧美激情视频| 亚洲一区二区三区在线看| 日韩av不卡一区二区| 久久人人精品| 加勒比久久高清| 伦理一区二区三区| 九色精品91| 999久久久国产精品| 日韩精品专区| 成人mm视频在线观看| 国产精品视频一区视频二区| 国产三级在线| 色一情一乱一伦一区二区三区日本| 成人综合视频在线| 青青草av网站| 日本女优北野望在线电影| 91破解版在线看| 国产日产精品久久久久久婷婷| 91精品久久久| 色综合一本到久久亚洲91| 国产成人免费av一区二区午夜| 国产一区在线电影| 午夜精品毛片| 亚洲国产aⅴ精品一区二区| 亚洲色图美国十次| 夜鲁夜鲁夜鲁视频在线播放| 欧美成人高清视频在线观看| 牛牛精品成人免费视频| 中文字幕免费一区二区| 免费视频最近日韩| 97aⅴ精品视频一二三区|