成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

彈性盒模型 flex box的認(rèn)知與使用

彈性盒子模型

布局方案

傳統(tǒng)的布局方案大多采用div+css+float+position+display來實現(xiàn),但是隨著css3中彈性盒子模型的推出,在前端布局方案中就又多出了一項彪悍的選項。
而因為最近在研究小程序,發(fā)現(xiàn)中間使用彈性盒子布局效果更好效率更高一點,所以就將之前學(xué)習(xí)彈性盒模型的相關(guān)知識點整理出來,給大家分享。

彈性盒模型flex布局介紹

彈性盒模型(flexbox)又稱為彈性布局,是css3中新提出的一種布局方式,通過彈性布局,可以讓子元素自動調(diào)整寬度和高度,從而達到很好的填充任何不同屏幕大小的顯示設(shè)備的顯示空間。
彈性盒模型與之前的布局方式是完全不同的兩種,雖然依然采用div+css的方式,但是卻將之前使用的浮動給替換成了彈性布局。從而使頁面元素布局方式更加的簡單。
不同于我們后面所學(xué)習(xí)的網(wǎng)格系統(tǒng),彈性布局更加適用于應(yīng)用組件以及小比例布局。
在之前,flex經(jīng)歷了三次迭代,每一次迭代都產(chǎn)生了不同的語法,目前我們學(xué)習(xí)遵循最終版本的語法。因為之前版本在使用的時候需要考慮兼容問題,而最新版本,所有的瀏覽器都支持無前綴的終極規(guī)范。

彈性盒子模型認(rèn)知

flex布局方式是一個完整的布局模塊,而不是只某個屬性。flex的布局主要依靠父容器和元素組成。
父容器稱之為flex container(flex容器) 而其子元素稱之為flex item(flex元素)。
而整個flex布局的核心在于 對其方式、排布和順序。

彈性盒子模型的使用

想要使用flex布局,首先要使用display:flex 或者 display:inline-flex來設(shè)置父容器。
display:flex 給父元素設(shè)置完成后,那么整個父元素會變成彈性容器,但是是一個塊級元素。
display:inline-flex給父元素設(shè)置完成后,那么整個父元素會變成彈性容器,但是是一個行內(nèi)塊級元素,有些類似于inline-block的效果。

當(dāng)父容器設(shè)置了這個屬性之后,里面的子元素默認(rèn)的全部變成flex item (flex元素)
Tip:flex布局與我們之前所學(xué)習(xí)的布局方式是屬于另外一套布局方案,所以在使用了flex布局之后,如Block”,“inline”,“float” 和 “text-align” 等一些屬性會失效。

<!DOCTYPE html>  <html lang="en">  <head>      <meta charset="UTF-8">      <title>Document</title>      <style>          .container-flex {              width: 600px;              border:1px solid #ccc;              display:flex;          }          .container-inline {              width: 600px;              border:1px solid #ccc;              display:inline-flex;          }          .container-flex div {              width: 200px;              height: 200px;              background-color: orange;          }          .container-inline div {              width: 200px;              height: 200px;              background-color: orange;          }      </style>  </head>  <body>      <div class="container-flex">          <div>1</div>          <div>2</div>          <div>3</div>          <div>4</div>      </div>      <div class="container-flex">          <div>1</div>          <div>2</div>          <div>3</div>          <div>4</div>      </div>      <div class="container-inline">          <div>1</div>          <div>2</div>          <div>3</div>          <div>4</div>      </div>      <div class="container-inline">          <div>1</div>          <div>2</div>          <div>3</div>          <div>4</div>      </div>  </body>  </html>

執(zhí)行的效果如下:

彈性盒模型 flex box的認(rèn)知與使用

必備名詞解釋

在使用彈性盒子模型之前,需要了解一些彈性盒模型的基礎(chǔ)概念名詞。

main axis 主軸
cross axis 交叉軸/側(cè)軸 與主軸垂直
main start 主軸起點邊
main end 主軸終點邊
cross start 交叉軸起點邊
cross end 交叉軸終點邊

彈性盒模型 flex box的認(rèn)知與使用

為什么使用彈性盒子模型

彈性盒子模型在開發(fā)手機端的時候使用頻率較高,在微信小程序開發(fā)的時候也是使用頻率非常高的技術(shù),可以通過幾個實例來看一下彈性盒子的好處:

實例1:

<!DOCTYPE html>  <html lang="en">  <head>      <meta charset="UTF-8">      <title>Document</title>      <style>          #item-container {              display: flex;/*啟用flex布局*/              background-color: pink;          }          .square {              width: 200px;              height: 200px;              background-color: orange;          }          .circle {              border-radius: 50%;              width: 150px;              height: 150px;              background-color: green;          }      </style>  </head>  <body>      <div id="item-container">          <div class="circle"></div>          <div class="square"></div>          <div class="circle"></div>      </div>  </body>  </html>

代碼結(jié)果如下:

彈性盒模型 flex box的認(rèn)知與使用

在上述實例中需要注意的點:
① 啟用flex布局 display:flex
② 父元素的子元素在父元素設(shè)置了display:flex之后,子元素會自動的變?yōu)閺椥院凶拥淖釉兀?br />被稱為flex items
③ 默認(rèn)情況,所有的 flex-item 會按照 flex 容器的頂部和左側(cè)對齊。

實例2:

<!DOCTYPE html>  <html lang="en">  <head>      <meta charset="UTF-8">      <title>Document</title>      <style>          #item-container {              display: flex;/*啟用flex布局*/              background-color: pink;              justify-content:flex-start;/*默認(rèn)*/              justify-content:flex-end;/*在主軸的末端對其*/              justify-content:center;/*在主軸的中間對其*/              justify-content:space-between;/*在整個主軸中平均分配空間,無論其中有多少個元素*/              justify-content:space-around;/*Flex-item 默認(rèn)會被均勻的分布,但是每一個                                          都會在其給定的空間內(nèi)居中顯示。*/              align-items:center;/*讓items在垂直方向上居中*/          }          .square {              width: 200px;              height: 200px;              background-color: orange;          }          .circle {              border-radius: 50%;              width: 150px;              height: 150px;              background-color: green;          }      </style>  </head>  <body>      <div id="item-container">          <div class="circle"></div>          <div class="square"></div>          <div class="circle"></div>      </div>  </body>  </html>

代碼效果如下:

彈性盒模型 flex box的認(rèn)知與使用

我們可以通過非常簡單的屬性設(shè)置來調(diào)整對其方式,例如:
justify-content: flex-start / flex-end /center /space-between /space-around
我們也可以通過align-items:center 屬性讓 items 在垂直方向居中。

實例3:

<!DOCTYPE html>  <html lang="en">  <head>      <meta charset="UTF-8">      <title>Document</title>      <style>          #item-container {              display: flex;/*啟用flex布局*/              background-color: pink;              justify-content:flex-start;/*默認(rèn)*/              justify-content:flex-end;/*在主軸的末端對其*/              justify-content:center;/*在主軸的中間對其*/              justify-content:space-between;/*在整個主軸中平均分配空間,無論其中有多少個元素*/              justify-content:space-around;/*Flex-item 默認(rèn)會被均勻的分布,但是每一個                                          都會在其給定的空間內(nèi)居中顯示。*/              align-items:center;/*讓items在垂直方向上居中*/          }          .square {              width: 200px;              height: 200px;              background-color: orange;              order: -1; /*讓正方形顯示在第一位而不是中間*/          }          .circle {              border-radius: 50%;              width: 150px;              height: 150px;              background-color: green;          }      </style>  </head>  <body>      <div id="item-container">          <div class="circle"></div>          <div class="square"></div>          <div class="circle"></div>      </div>  </body>  </html>

實例3 和 實例2 大體相似,但是在.square類里存在一句order:-1,可以更改元素的渲染順序。這個是彈性盒模型中一個非常厲害的一個方面。

實例3代碼效果如下:

彈性盒模型 flex box的認(rèn)知與使用

flex布局方式屬性

在flex整個體系當(dāng)中,大體上可以分為兩類,一類是給父容器設(shè)置的屬性,一類是給父容器中子元素設(shè)置的屬性。

彈性容器屬性 — 給父元素設(shè)置的屬性

1.flex-direction 定義內(nèi)部元素如何在flex容器中布局,定義了主軸的方向(是正是反)。

語法:

row | row-reverse | column | column-reverse
row 默認(rèn)值,子元素會排列在一行 從主軸左側(cè)開始
row-reverse 子元素會排列在一行。不過是從右側(cè)開始
column 子元素垂直顯示,從側(cè)軸起始點開始
column-reverse 垂直顯示,不過從結(jié)束點開始

實例代碼:

<!DOCTYPE html>  <html lang="en">  <head>      <meta charset="UTF-8">      <title>Document</title>      <style>          .container {              width: 100%;              height: 500px;              border:1px solid #ccc;              display:flex;              flex-direction: row-reverse;              flex-direction: column;              flex-direction: column-reverse;          }          .container div {              width: 100px;              height: 100px;              background-color: orange;          }      </style>  </head>  <body>      <div class="container">          <div>1</div>          <div>2</div>          <div>3</div>      </div>  </body>  </html>

2.flex-wrap 控制容器內(nèi)的子元素是被強制放在一行中或者是被放在多個行上 。如果允許換行,這個屬性允許你控制行的堆疊方向。

語法:
nowrap | wrap | wrap-reverse
nowrap 所有的元素被擺在一行 默認(rèn)值
wrap 當(dāng)一行元素過多,則允許元素 換行
wrap-reverse 將側(cè)軸起點和終點顛倒

實例代碼:

<!DOCTYPE html>  <html lang="en">  <head>  <meta charset="UTF-8">  <title>Document</title>  <style>      .container {          width: 600px;          height: 500px;          border:1px solid #ccc;          display:flex;          flex-wrap:wrap;          flex-wrap:wrap-reverse;      }      .container div {          width: 200px;          height: 100px;          background-color: orange;      }  </style>  </head>  <body>  <div class="container">      <div>1</div>      <div>2</div>      <div>3</div>      <div>4</div>      <div>5</div>      <div>6</div>      <div>7</div>      <div>8</div>      <div>9</div>      <div>10</div>  </div>  </body>  </html>

3.justify-content 屬性定義了瀏覽器如何分配順著父容器主軸的彈性(flex)元素之間及其周圍的空間。

語法:
flex-start | flex-end | center | space-between | space-around
flex-start : 從行首開始排列。每行第一個彈性元素與行首對齊,同時所有后續(xù)的彈性元素與前一個對齊。默認(rèn)
flex-end : 從行尾開始排列。每行最后一個彈性元素與行尾對齊,其他元素將與后一個對齊
center : 伸縮元素向每行中點排列。每行第一個元素到行首的距離將與每行最后一個元素到行尾的距離相同
space-between : 在每行上均勻分配彈性元素。相鄰元素間距離相同。每行第一個元素與行首 對齊,每行最后一個元素與行尾對齊。
space-around : 在每行上均勻分配彈性元素。相鄰元素間距離相同。每行第一個元素到行首的距離和每行最后一個元素到行尾的距離將會是相鄰元素之間距離的一半。

實例代碼:

參考上面的實例2.

4.align-items 屬性以與justify-content相同的方式在側(cè)軸方向上將當(dāng)前行上的彈性元素對齊。

語法:
flex-start | flex-end | center | baseline | stretch
align-items: flex-start; 對齊到側(cè)軸起點
align-items: flex-end; 對齊到側(cè)軸終點
align-items: center; 在側(cè)軸上居中
align-items: baseline; 與基準(zhǔn)線對齊
align-items: stretch; 拉伸元素以適應(yīng) 默認(rèn)值

實例代碼:

<!DOCTYPE html>  <html lang="en">  <head>  <meta charset="UTF-8">  <title>Document</title>  <style>      #item-container {          display: flex;/*啟用flex布局*/          background-color: pink;          justify-content:space-around;          align-items:baseline;/*與基準(zhǔn)線對齊*/      }      .square {          width: 200px;          height: 200px;          background-color: orange;      }      .circle {          border-radius: 50%;          width: 150px;          height: 150px;          background-color: green;      }      .container {          width: 500px;          height: 600px;          border:1px solid #ccc;          display:flex;          align-items: stretch;      }      .container div {          width: 100px;          background-color:red;          border:1px solid green;      }  </style>  </head>  <body>  <div id="item-container">      <div class="circle"></div>      <div class="square"></div>      <div class="circle"></div>  </div>  <!-- <div class="container">      <div>1</div>      <div>2</div>  </div> -->  </body>  </html>

5.align-content 多行對其方式,如果只有一行,則失效。

語法:
flex-start | flex-end | center | space-between | space-around | stretch
flex-start : 與交叉軸的起點對其
flex-end : 與交叉軸的終點對其
center : 與交叉軸的中點對其
space-between : 與交叉軸兩端對其,軸線之間的間隔平均分布
space-around: 所有行在容器中平均分布,相鄰兩行間距相等。容器的垂直軸起點邊和終點邊分別與第一行和最后一行的距離是相鄰兩行間距的一半。
stretch :拉伸所有行來填滿剩余空間。剩余空間平均的分配給每一行

實例代碼:

<!DOCTYPE html>  <html lang="en">  <head>      <meta charset="UTF-8">      <title>Document</title>      <style>          .container {              width: 600px;              height: 900px;              border:1px solid #ccc;              display:flex;              flex-wrap:wrap;              align-content:flex-start;              align-content:flex-end;              align-content:center;              align-content:space-between;              align-content:space-around;              align-content:stretch; /*默認(rèn)*/          }          .container div {              width: 200px;              height: 80px;              background-color: orange;          }      </style>  </head>  <body>      <div class="container">          <div>1</div>          <div>2</div>          <div>3</div>          <div>4</div>          <div>5</div>          <div>6</div>          <div>7</div>          <div>8</div>          <div>9</div>          <div>10</div>      </div>  </body>  </html>

彈性元素屬性 — 給子元素設(shè)置的屬性

order order屬性規(guī)定了彈性容器中的可伸縮項目在布局時的順序。元素按照order屬性的值的增序進行布局。擁有相同order屬性值的元素按照它們在源代碼中出現(xiàn)的順序進行布局。

語法:
order:

align-self 定義flex子項單獨在側(cè)軸(縱軸)方向上的對齊方式

語法:
stretch|center|flex-start|flex-end|baseline

flex-grow 定義彈性盒子元素擴展比率
flex-shrink 定義彈性盒子元素的收縮比率
flex-basis 指定了flex item在主軸方向上的初始大小。如果不使用box-sizing來
改變盒模型的話,那么這個屬性就決定了flex item的內(nèi)容盒content-box)的寬 或者高(取決于主軸的方向)的尺寸大小。

Tip:需要注意的是,在上面的最后的flex-grow、flex-shrink、flex-basis 三個屬性最好相互搭配使用。

實例:

<!DOCTYPE html>  <html>  <head>  <meta charset="utf-8">  <style>  #main {      width: 350px;      height: 100px;      border: 1px solid #c3c3c3;      display: flex;  }    #main div {      flex-grow: 1;      flex-shrink: 1;      flex-basis: 100px;  }    #main div:nth-of-type(2) {      flex-shrink: 3;  }  </style>  </head>  <body>    <div id="main">    <div style="background-color:coral;"></div>    <div style="background-color:lightblue;"></div>    <div style="background-color:khaki;"></div>    <div style="background-color:pink;"></div>    <div style="background-color:lightgrey;"></div>  </div>  </body>  </html>

ok,上面大概就是一些常用的彈性盒子模型flex-box常用的屬性,上面的實例很多只是給了代碼,沒有給效果圖,是因為希望正在學(xué)習(xí)彈性盒子模型的同志們最好把代碼實際的敲一下,并且親自嘗試不同的屬性值,來分析不同屬性帶來的不同的效果。
彈性盒子模型難度不大,但是卻與傳統(tǒng)的布局方案有很大的差別。

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
欧美群交在线播放1| 日本XXXX色视频在线观看免费, | 精品国产制服丝袜高跟| 久久99精品久久久久久HB无码| 久久亚洲AV成人无码国产电影| 男男gv在线观看| 人妻洗澡被强公日日澡| 天天想你在线视频免费观看高清版 | 亚洲AV无码成人影院一尤物区| 亚洲人成色A777777在线观| 真实的国产乱XXXX在线| WWW.色五月.COM| 国产成人8X视频网站| 极品YIN荡人妻合集H| 久久亚洲国产成人影院| 欧美精品亚洲精品日韩专区VA| 色婷婷精品久久二区二区蜜臀av| 西西人体444WWW大胆无码视| 亚洲欲色欲色XXXXX在线| GOGO人体大胆瓣开下部L| 国产成人AV免费网址| 精品无码国产污污污免费| 哦┅┅快┅┅用力啊┅┅ | 敌伦交换第21部分正文内容| 国产日韩精品一区二区三区在线观| 久久精品国产亚洲AV蜜臀色欲| 欧美男女一进一出| 无码精品毛片波多野结衣| 亚洲色偷偷综合亚洲AV78| 70老少配另类BBW| 国产产在线精品亚洲AAVV| 久久99精品国产麻豆婷婷| 欧美日韩精品视频一区二区三区| 天堂在/线资源中文在线BT| 一本丁香综合久久久久不卡网站| 亚洲综合激情另类专区| 亚洲国产成人一区二区精品区| 又粗又大又硬毛片免费看| 芭乐小猪幸福宝丝瓜草莓官网| 国产精品人成在线播放新网站| 久久久久人妻一区精品性色AV | 经典精品毛片免费观看| 欧美国产成人精品一区二区三区| 无码AV专区丝袜专区| 伊人涩涩涩涩久久久AV| 福利 无码 三级 视频| 精品无人乱码高清| 人善之交Z0OZO0D0G人善| 亚洲AV成人无码一区在线观看| 中文字幕一区二区精品区| 国产成人无码AA精品一区 | 人妻AV中文字幕一区二区三区| 亚洲AV永久无码精品三区在线4| 99久久久无码国产精品9| 国产亚洲精品一区在线播放| 欧美成人精品高清在线观看| 亚洲AV美女一区二区三区| H无遮挡H无码黄3D漫画| 激情国产AV做激情国产爱| 日本久久夜夜一本婷婷| 亚洲中文在线精品国产| 国产超碰人人爽人人做| 男按摩师舌头伸进去了| 亚洲AV无码乱码一级毛片孕妇| MD豆传媒一二三区| 久久发布国产伦子伦精品| 日韩少妇人妻夜夜爽| 在线 | 一区二区三区四区| 国产精品久久久久久免费软件 | 亚洲A∨精品无码一区二区| MONSTER无删减动漫| 久久国产欧美成人网站| 无码人妻精品中文字幕免费东京热| 2021精品久久久久精品免费网| 黑料不打烊吃瓜爆料| 啊轻点灬大JI巴太粗太长了在线| 国产 浪潮AV性色四虎| 国产 麻豆 日韩 欧美 久久| 果冻传媒AⅤ毛片无码蜜桃| 中文字幕亚洲乱码熟女一区二区| 别揉我奶头~嗯~啊~| 麻豆国产在线精品国偷产拍| 亚洲AV成人午夜福利在线观看| 被男人吃奶很爽的毛片| 裸体美女扒开下部无遮挡网站免费 | 人妻中文乱码在线网站| 一女大战七个黑人到喷浆| 国产清纯美女爆白浆视频| 日韩免费视频一一二区| 97精品伊人久久久大香线蕉| 精品亚洲韩国一区二区三区| 无码人妻久久一区二区三区| 本道久久综合无码中文字幕| 免费观看四虎精品国产地址| 亚洲人精品午夜射精日韩| 国产精品青青在线麻豆| 日日躁夜夜躁狠狠久久AV| AV一本大道香蕉大在线| 老师你乖乖的可以让你少吃点苦头 | 日韩精品久久久久久免费| 97porm国内自拍视频| 老公和兄弟一前一后攻击 | 久久精品国产亚洲AV麻豆甜| 亚洲AV无码久久精品成人| 国产精品久久久亚洲| 天堂√在线中文资源网| 厨房征服丰满熟妇在线观看| 强奷漂亮少妇高潮麻豆| 99精品视频一区在线观看| 麻豆国产精品VA在线观看| 亚洲一区二区三区无码国产| 精产国品一二三产品区别在哪| 亚洲AV无码乱码在线观看四虎| 国产精品高潮露脸在线观看| 首页 图区 国产 亚洲 欧美| 丰满饱满极品熟妇XXXX| 日韩人妻无码精品久久| 波多野结衣HD在线观看| 人人做天天爱夜夜爽2020| WWW国产成人免费观看视频| 欧美成人影院亚洲综合图| 99久久人妻精品免费一区| 女朋友特别闷骚很吸引别人 | 亚洲乱码尤物193YW最新网站 | 亚洲国产成人久久一区WWW| 和儿媳妇在一起最幸福的句子| 亚洲AV无码国产精品久久不卡| 国内精品久久久久久久影院| 亚洲AV成人无码一二三在线观看| 国产人久久人人人人爽| 新妺妺窝人体色WWW| 国产综合无码一区二区色蜜蜜| 亚洲AV成人片乱码色午夜| 国精产品一区一区三区有限| 亚洲AV无码国产精品夜色午夜 | 国产一区二区波多野结衣| 亚洲AV成人无码网站大全唐人| 黑人精品一区二区三区| 亚洲精品无码专区久久久| 久久精品人妻少妇一区二区| 亚洲综合国产精品第一页| 美女裸体A级毛片| 99在线精品国自产拍| 人妻丰满熟妇AⅤ无码区| 成人亚洲AV日韩AV欧v| 特级毛片A级毛片免费观看网站| 国产精品无码一区二区三区不卡 | 小东西好几天没弄了还能吃吗| 国精产品砖一区二区三区糖心| 亚洲成人AV在线播放| 久久精品国产久精国产思思| 中国老妇XXXX性开放| 欧美日韩精品SUV| 成熟丰满熟妇高潮XXXXX视频| 十八禁啪啪污污网站免费下载 | 久久精品九九热无码免贵| 真人作爱90分钟免费看视频| 欧美老熟妇XB水多毛多| 成人无号精品一区二区三区| 无码人妻熟妇av又大又粗浪潮 | 全免费A级毛片免费看网站| 短乱俗小说500篇免费下载| 小妖精含牢了我喂饱你| 国产AV无码专区影视| 亚洲 小说 欧美 激情 另类| 国产同性GV男男在线观看| 日日麻批免费40分钟无码| 日本又黄又爽又色又刺激的视频 | 欧美性爱视频第一页| 国产ww又大又粗又刺激孕妇| 亚洲成AV人片乱码色午夜| 久久亚洲精品无码观看| 暗交小拗女一区二区三| 午夜香吻高清观看视频在线| 久久久国产精品VA麻豆| YSL小金管水蜜桃色| 无线乱码A区B区C区D| 久久亚洲AV成人无码精品 | 中文字幕人妻无码系列第三区| 日本真人裸交试看120秒| 国产午夜精品一区二区三区漫画| 一边做一边说国语对白| 日韩成人一区二区三区在线观看| 国产一精品一AV一免费爽爽| 中文在线っと好きだった| 色婷婷婷亚洲综合丁香五月| 好满射太多了装不下了APP| 7777久久亚洲中文字幕| 无码人妻久久一区二区三区蜜桃| 久久久久久精品免费免费WEI | 日本精品VIDEOSSE×少妇| 韩国V欧美V亚洲V日本| 中文字字幕乱码视频高清| 天堂いっしょにしよ在线| 久久强奷乱码老熟女网站| 吃奶呻吟打开双腿做受是免费视频| 亚洲国产一区二区A毛片| 强行挺进美艳老师的后臀| 红桃视频成人传媒| 波多野结衣守望人妻理论|