首页 >web前端 >html教程 >flexbox 伸缩布局盒 - HappyForEverIsaDream

flexbox 伸缩布局盒 - HappyForEverIsaDream

WBOY
WBOY原创
2016-05-21 08:42:431667浏览

Flexbox(伸缩布局盒) 是 CSS3 中一个新的布局模式,为了现代网络中更为复杂的网页需求而设计。

Flexbox 由 伸缩容器 和 伸缩项目 组成。通过设置元素的 display 属性为    flex  或  inline-flex     可以得到一个伸缩容器

            设置为flex的容器被渲染为一个块级元素,而设置为inline-flex的容器则渲染为一个行内元素。

例如:此处将 类名为   flex-container   的元素设置为伸缩容器

.flex-container {
display-webkit-flex;
displayflex;
}

伸缩容器中的每一个子元素都是一个伸缩项目。伸缩项目可以是任意数量的。伸缩容器外和伸缩项目内的一切元素都不受影响。

简单地说,Flexbox 定义了伸缩容器内伸缩项目该如何布局。

 

Flex Lines 伸缩行       

伸缩项目沿着伸缩容器内的一个 伸缩行 定位。通常每个伸缩容器只有一个伸缩行。  默认伸缩行从左往右

例子:

<span style="color: #008080;"> 1</span> <span style="color: #800000;"><div class="flex-container">
<span style="color: #008080;"> 2</span> <span style="color: #800000;"><div class="flex-item">flex item 1</div>
</span><span style="color: #008080;"> 3</span> <span style="color: #800000;"><div class="flex-item">flex item 2</div>
</span><span style="color: #008080;"> 4</span> <span style="color: #800000;"></span>
</div>
</span><span style="color: #008080;"> 5</span> 
<span style="color: #008080;"> 6</span> <span style="color: #800000;">样式:
</span><span style="color: #008080;"> 7</span> 
<span style="color: #008080;"> 8</span> <span style="color: #800000;">.flex-container </span>{
<span style="color: #008080;"> 9</span> <span style="color: #ff0000;">display</span>:<span style="color: #0000ff;"> -webkit-flex</span>;
<span style="color: #008080;">10</span> <span style="color: #ff0000;">display</span>:<span style="color: #0000ff;"> flex</span>;
<span style="color: #008080;">11</span> <span style="color: #ff0000;">width</span>:<span style="color: #0000ff;"> 300px</span>;
<span style="color: #008080;">12</span> <span style="color: #ff0000;">height</span>:<span style="color: #0000ff;"> 240px</span>;
<span style="color: #008080;">13</span> <span style="color: #ff0000;">background-color</span>:<span style="color: #0000ff;"> Silver</span>;
<span style="color: #008080;">14</span> }
<span style="color: #008080;">15</span> 
<span style="color: #008080;">16</span> <span style="color: #800000;">.flex-item </span>{
<span style="color: #008080;">17</span> <span style="color: #ff0000;">background-color</span>:<span style="color: #0000ff;"> DeepSkyBlue</span>;
<span style="color: #008080;">18</span> <span style="color: #ff0000;">width</span>:<span style="color: #0000ff;"> 100px</span>;
<span style="color: #008080;">19</span> <span style="color: #ff0000;">height</span>:<span style="color: #0000ff;"> 100px</span>;
<span style="color: #008080;">20</span> <span style="color: #ff0000;">margin</span>:<span style="color: #0000ff;"> 5px</span>;
<span style="color: #008080;">21</span> }
View Code

 

效果图:

再加

<div class="flex-item">flex item 3</div>
<div class="flex-item">flex item 4</div><br><br>伸缩项目的宽度超过了 伸缩容器的宽度,伸缩容器的宽度不会改变,伸缩项目的宽度减小<br><br><br><br>
<span style="color: #008080;"> 1</span> <span style="color: #800000;"><div class="flex-container">
<span style="color: #008080;"> 2</span> <span style="color: #800000;"><div class="flex-item">flex item 1</div>
</span><span style="color: #008080;"> 3</span> <span style="color: #800000;"><div class="flex-item">flex item 2</div>
</span><span style="color: #008080;"> 4</span> <span style="color: #800000;"></span>
</div>
</span><span style="color: #008080;"> 5</span> 
<span style="color: #008080;"> 6</span> 
<span style="color: #008080;"> 7</span> <span style="color: #800000;">CSS样式
</span><span style="color: #008080;"> 8</span> <span style="color: #800000;">.flex-container </span>{
<span style="color: #008080;"> 9</span> <span style="color: #ff0000;">   direction</span>:<span style="color: #0000ff;"> rtl</span>;
<span style="color: #008080;">10</span> <span style="color: #ff0000;">    display</span>:<span style="color: #0000ff;"> -webkit-flex</span>;
<span style="color: #008080;">11</span> <span style="color: #ff0000;">    display</span>:<span style="color: #0000ff;"> flex</span>;
<span style="color: #008080;">12</span> <span style="color: #ff0000;">    width</span>:<span style="color: #0000ff;"> 300px</span>;
<span style="color: #008080;">13</span> <span style="color: #ff0000;">    height</span>:<span style="color: #0000ff;"> 240px</span>;
<span style="color: #008080;">14</span> <span style="color: #ff0000;">    background-color</span>:<span style="color: #0000ff;"> Silver</span>;
<span style="color: #008080;">15</span>     
<span style="color: #008080;">16</span> }
<span style="color: #008080;">17</span> 
<span style="color: #008080;">18</span> <span style="color: #800000;">.flex-item </span>{
<span style="color: #008080;">19</span> <span style="color: #ff0000;">    background-color</span>:<span style="color: #0000ff;"> DeepSkyBlue</span>;
<span style="color: #008080;">20</span> <span style="color: #ff0000;">    width</span>:<span style="color: #0000ff;"> 100px</span>;
<span style="color: #008080;">21</span> <span style="color: #ff0000;">    height</span>:<span style="color: #0000ff;"> 100px</span>;
<span style="color: #008080;">22</span> <span style="color: #ff0000;">    margin</span>:<span style="color: #0000ff;"> 5px</span>;
<span style="color: #008080;">23</span> }
View Code

效果:

伸缩行从右往左,文字也从右往左

 

 

为了描述抽象的书写模式,Flexbox 使用 主轴 和 侧轴的概念。伸缩行跟随主轴。侧轴则垂直于主轴。

flex-direction 伸缩流的方向

默认值  row   

再次提醒,默认是从左至右,从上到下。其他的值如下:

  • row-reverse: 主轴起点和主轴终点交换。如果书写模式是从左至右,伸缩项目则是从左往右显示。
  • column: 主轴和侧轴交换。如果书写系统是垂直的,那么伸缩项目也是垂直显示的。
  • column-reverse: 和 column 一样,但是方向相反。

 

justify-content 主轴对齐

 

用于调整主轴上伸缩项目的位置。可能的值为:

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

 

 align-items 侧轴对齐

调整伸缩项目在侧轴上的定位方式。可能的值有:

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

 

flex-wrap 伸缩行换行

为伸缩容器创建多个伸缩行。这个属性接受以下值:

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

 

align-content 堆栈伸缩行

它对齐的是伸缩行,它接受的值:

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

 

flex-flow 伸缩方向与换行    是flex-directionflex-wrap的缩写。

 

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn