美文网首页
响应式布局:CSS3弹性盒flex布局模型

响应式布局:CSS3弹性盒flex布局模型

作者: fdeb17225224 | 来源:发表于2018-12-05 10:50 被阅读5次

原文:https://blog.csdn.net/dx18520548758/article/details/54316024

页面布局一直都是web应用样式设计的重点
我们传统的布局方式都是基于盒模型的
利用display、position、float来布局有一定局限性
比如说实现自适应垂直居中
随着响应式布局的流行,CSS3引入了更加灵活的弹性布局模型

flex弹性布局

使用弹性布局可以有效的分配一个容器的空间
即使我们的容器元素尺寸改变
它内部的元素也可以调整它的尺寸来适应空间

20161124181235115.gif

若想让一个元素变成弹性盒
很简单

.demo { /*块级元素*/
    display: flex;
}

.demo { /*行级元素*/
    display: inline-flex;
}

设置了flex布局后,子元素的float、clear和vertical-align属性就会失效

举个小例子

<div class="flex-box">
    <div class="flex-item">1</div>
    <div class="flex-item">2</div>
    <div class="flex-item">3</div>
</div>

.flex-box {
    width: 500px;
    height: 100px;
    border: 1px solid black;
}
.flex-item {
    width: 100px;
    height: 100px;
    font-size: 80px;
    line-height: 100px;
    text-align: center;
}
.flex-item:nth-child(1) {
    background-color: lightseagreen;
}
.flex-item:nth-child(2) {
    background-color: violet;
}
.flex-item:nth-child(3) {
    background-color: cornflowerblue;
}
20161124105959301.png

正常情况下,子元素div默认占满一行,所以他们只能纵向排列

现在我们使用弹性布局

.flex-box {
    display: flex; /*增*/
    width: 500px;
    height: 100px;
    border: 1px solid black;
}
20161124110007797.png

我们发现子元素在父元素中呈现行排列
看起来好像子元素应用了浮动float
但这个属性远远没有这么简单
现在才刚刚开始(⊙▽⊙)

相关概念

在讲那些属性之前,我们先来看一些基本概念
设置了flex布局的元素,称为“flex容器”,简称“容器”
它的子元素,称为“flex项目”,简称“项目”
这里我引入一张图(原谅我的盗图,自己懒得画了..)

20161124102418233.png

“容器”中有两条垂直的坐标轴
横向的叫做主轴
纵向的叫做交叉轴
主轴左边与右边分别叫做主轴起点与主轴终点
交叉轴上边与下边分别叫做交叉轴起点与交叉轴终点

“项目”也有两个名词
每个项目的宽与高叫做主轴尺寸与交叉轴尺寸

这回我们就能理解了为什么使用弹性布局后子元素呈现行排列
项目在容器中就是沿着主轴排列的

容器属性

弹性盒布局“容器”有如下属性

  • flex-flow:flex-direction,flex-wrap
  • justify-content
  • align-items
  • align-content

flex-direction

我们可以使用flex-direction指定主轴的方向,从而改变项目的排列方向
属性值:

  • row(默认)
  • row-reverse
  • column
  • column-reverse
.flex-box {
    display: flex;
    width: 500px;
    height: 100px;
    border: 1px solid black;
    flex-direction: row-reverse; /*增*/
}
20161124110615836.png

其他属性也不多解释了,很好理解


20161124110641493.png

这张图片分别对应了column-reverse、column、row、row-reverse

flex-wrap

我们弹性盒的项目默认都是排列在一个轴上的
这样如果项目多的话,会“弹性”压缩在一行
比如说我多加一些项目

20161124111217087.png

我并没有改变项目的宽
但是由于处于弹性盒中项目过多,项目在主轴上被压缩

现在添加flex-wrap属性

.flex-box {
    ......
    flex-wrap: wrap; /*增*/
}
20161124111702558.png

flex-wrap: wrap可以让我们指定当容器“装不下”项目时,是否换行
属性值如下:

  • no-wrap
  • wrap
  • wrap-reverse
    前两个我们都理解了
    第三个属性值wrap-reverse
    换行的项目会排在上面像这样


    20161124112218404.png

flex-flow

flex-flow是flex-direction和flex-wrap的复合属性
两个属性都是必写的
就不多解释了

justify-content

justify-content属性定义了项目在主轴上的对齐方式
属性值如下:

  • flex-start:左对齐(默认)
  • flex-end:右对齐
  • center:居中
  • space-between:两端对齐(项目间间隔相同)
  • space-around:两端间隔对齐(项目间间隔是项目与边框间隔的2倍)
    flex-start :


    20161124112736693.png

flex-end:


20161124112828281.png

center:


20161124112922219.png

space-between:


20161124113019626.png

space-around:


20161124113108276.png

align-items

align-items属性定义项目在交叉轴上如何对齐
属性值如下:

  • stretch:未设置高度(或height: auto)的项目占满整个容器高度(默认)
  • flex-start :交叉轴起点对齐
  • flex-end:交叉轴终点对齐
  • center:交叉轴中点对齐
  • baseline:项目第一行文字的基线对齐
    flex-start:


    20161124113923160.png

flex-end:


20161124114008788.png

center:


20161124114106336.png

baseline:


20161124122529080.png

align-content

align-content属性定义多根轴线的对齐方式
这个属性只有在容器有多条主轴是才有效,一条主轴无效
类似于justify-content属性
属性值如下:

  • stretch:轴线占满整个交叉轴(默认值)
  • flex-start:与交叉轴的起点对齐
  • flex-end:与交叉轴的终点对齐
  • center:与交叉轴的中点对齐
  • space-between:与交叉轴两端对齐,轴线间间隔相等
  • space-around:每根轴线两侧的间隔都相等
    flex-start:


    20161124123211557.png

flex-end:


20161124123250717.png

center:


20161124123329045.png

space-between:


20161124123405387.png

space-around:


20161124123441404.png

项目属性

弹性盒布局“项目”有如下属性

  • order
  • flex:flex-grow、flex-shrink、flex-basis
  • align-self

order

order允许我们自定义项目的排列顺序
默认为0,属性值是数字,数值越小越靠前
有点类似我们优先队列中的优先级

.flex-item:nth-child(1) {
    ......
    order: 99;
}
.flex-item:nth-child(2) {
    ......
    order: -1;
}
.flex-item:nth-child(3) {
    ......
}
20161124124659609.png

flex-grow

flex-grow定义项目的放大比例
默认是0,就是如果没有占满容器整行,也不放大项目,就像上面的图片

.flex-item:nth-child(1) {
    ......
    flex-grow: 1; <--
}
.flex-item:nth-child(2) {
    ......
    flex-grow: 2; <--
}
.flex-item:nth-child(3) {
    ......
    flex-grow: 3; <--
}
20161124125117756.png

这就相当于三个项目把剩下的空间“切成”6块
项目一拿走1块,项目二拿走2块,项目三拿走3块

flex-shrink

flex-shrink定义项目的缩小比例
默认是1,就是如果空间不足,该项目将等比缩小
通过这个属性我们可以控制各个项目缩小的比例

.flex-item:nth-child(1) {
    ......
    flex-shrink: 1; <--
}
.flex-item:nth-child(2) {
    ......
    flex-shrink: 2; <--
}
.flex-item:nth-child(3) {
    ......
    flex-shrink: 3; <--
}
20161124125503698.png

这样各个项目缩小的比例就是 1:2:3
从而保证所有项目总宽度和容器宽度相等

flex-basis

flex-basis定义在分配多余空间之前,项目占据的主轴空间
默认auto,就是项目本来的宽度
我们可以手动设置长度

.flex-item:nth-child(1) {
    ......
    flex-basis: 150px; <--
}
.flex-item:nth-child(2) {
    ......
}
.flex-item:nth-child(3) {
    ......
}
20161124130222463.png

flex

flex是flex-grow、flex-shrink、flex-basis的复合属性
默认值:0 1 auto,后两个属性可选
可以写关键字:auto (1 1 auto) 和 none (0 0 auto)

align-self

align-self属性允许个别项目拥有与众不同的对齐方式
就是会覆盖align-items设置的对齐属性
默认值auto,继承弹性容器的align-items属性值
属性值除了auto外,和align-items一样,就不多解释了

  • auto
  • stretch
  • flex-start
  • flex-end
  • center
  • baseline
.flex-box {
    ......
    align-items: center;
}
.flex-item:nth-child(2) {
    ......
    align-self: flex-end;
}

20161124131051581.png

弹性盒的全部属性就是这些了
其实这些都是最新的语法
在此之前浏览器的实现都不一致,了解一下就好了

  • 2009年规范语法:
    display: box
  • 2011年非官方规范语法:
    display: flexbox
  • 最新版本规范语法:
    display: flex

相关文章

  • [读]响应式布局:CSS3弹性盒flex布局模型

    响应式布局:CSS3弹性盒flex布局模型

  • 面试3:flex弹性盒布局

    课程思维导图 Flex 弹性盒布局 CSS3弹性盒布局的理解: web应用有不同设备尺寸和分辨率,这时需要响应式界...

  • display:flex(弹性盒模型)

    display:flex(弹性盒模型),经常用在响应式开发中。行式布局 flex-flow: row;html css:

  • CSS面试考点之Flex布局和Grid网格布局

    1、flexbox(弹性盒布局模型) Flexible Box简称flex,意为”弹性布局”,可以简便、完整、响应...

  • 移动端开发

    视口 屏幕适配 布局 流体布局 响应式布局 rem布局 弹性盒模型布局

  • CSS布局之——Flex布局

    随着CSS3的到来,Flex布局出现了,Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型...

  • flex-box属性总结

    概述 CSS3引入了一种新的布局模型——flex布局。flex是flexible box的缩写,一般称为弹性盒模型...

  • flex 弹性布局盒模型

    flex 弹性布局盒模型 设置弹性盒模型 display:flex (新版) display:-webkit-b...

  • flex布局

    Flex 弹性布局能为盒状模型提供最大的灵活性,可以简便完整响应式地实现各种页面布局。对布局还不是很 OK 的我决...

  • flex 弹性盒子

    弹性盒子是 CSS3 的一种新的布局模式Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型...

网友评论

      本文标题:响应式布局:CSS3弹性盒flex布局模型

      本文链接:https://www.haomeiwen.com/subject/obevcqtx.html