10分钟理解CSS3 FlexBox弹性布局


Posted in HTML / CSS onDecember 20, 2018

基本介绍

特点

  • flexbox是一种css display类型,提供一种更简单高效的布局方式;
  • flexbox可以对元素相对于父元素、兄弟元素进行定位、控制尺寸、控制间距;
  • flexbox对响应式有很好的支持;

工作原理

设置父元素的display属性为flex,则子元素都变成flex item,由此可以控制子元素的排列方式、尺寸、间距等;

兼容性

10分钟理解CSS3 FlexBox弹性布局

Flex Container

先来看一个最简单的flex示例,外层div设置display: flex成为一个flex container,内部的3个div则自动变为flex item:

html:

<div class="flex-container">
  <div class="box one"></div>
  <div class="box two"></div>
  <div class="box three"></div>
</div>

css:

.flex-container{ max-width: 960px; margin: 0 auto; display:flex; }
.box{ height: 100px; min-width: 100px; }
.one{ background: pink; }
.two{ background: lightgreen; }
.three{ background: skyblue; }

效果:

10分钟理解CSS3 FlexBox弹性布局

效果与浮动布局类似,但是如果用浮动实现的话需要写更多的代码,而flex一行就搞定了。

1. Justify Content

如果我们想让flex item居中排列呢,我们可以给flex container增加一个css属性:justify-content,它控制flex item在主轴方向(main axis,由flex-drection决定,默认为水平方向)上的对齐方式:

.flex-container{
  ...
  justify-content: center;
}

效果如图:

10分钟理解CSS3 FlexBox弹性布局

除此之外justify-content还可以设置为flex-start, flex-end, space-around, space-between, space-even等值,具体效果请自行实验。

2. Align Items

实现了flex方向的居中后,垂直于主轴方向(cross axis)的居中可以用align-items实现。

css:

.flex-container{
  max-width: 960px;
  margin: 0 auto;
  display:flex;
  justify-content: center;
  height: 200px;
  background-color: white;
  align-items: center;
}

效果:

10分钟理解CSS3 FlexBox弹性布局

使用flex解决了以往css垂直居中实现复杂的问题!相应的,align-items还有flex-start, flex-end等其他值。

3. Flex Direction

flex-direction决定了主轴方向即flex item排列方向,除了默认的row方向之外,还可以纵向、反向(row-reverse/column-reverse)排列flex item:

css:

.flex-container{
  ...
  
  flex-direction: column;
  align-items: center;
}

效果:

10分钟理解CSS3 FlexBox弹性布局

4. Flex Wrap

如果我们不想在窗口变窄的情况下压缩flex item,而是让超出边界的flex item换行显示那我们可以设置flex container的flex-wrap

.flex-container{
  max-width: 960px;
  margin: 0 auto;
  display:flex;
  flex-wrap: wrap;
}

.box{
  height: 100px;
  min-width: 300px;
  flex-grow: 1;
}

当我们压缩窗口的时候,效果如下:

10分钟理解CSS3 FlexBox弹性布局

flex wrap还有一个值:wrap-reverse,设置该值后,被wrap的元素会排到其他元素上面:

10分钟理解CSS3 FlexBox弹性布局

由此可见,flex wrap一定程度上可以取代media query了。

5. Flex Row

最后,flex-directionflex-wrap可以合并为一个属性flex-flow,比如:flex-flow: row-reverse wrap

Flex Item

1. Flex Grow

在上面所有的例子中,三个flex item只占据了flex container小部分空间,如果想让flex item占满flex container我们需要给flex item设置flex-grow属性。顾名思义,grow意味着增长,用于控制flex item的尺寸的伸展。

将css修改为:

.box { 
    height: 100px; 
    min-width: 100px; 
    flex-grow:1; 
}

效果:

10分钟理解CSS3 FlexBox弹性布局

可以看到三个子元素平分了父元素的空间,因为此时它们的flex-grow都是1。如果只有一个子元素设置了flex-grow呢?

css:

.box{ height: 100px; min-width: 100px; }
.one{ background: pink; flex-grow: 1; }

效果:

10分钟理解CSS3 FlexBox弹性布局

此时two和three的大小不变,而one占据了父元素剩余空间。

如果将one的flex-grow改为2,而two和three改为1,我们看看会发生什么:

css:

.box{ height: 100px; min-width: 100px; flex-grow:1; }
.one{ background: pink; flex-grow: 2; }

效果:

10分钟理解CSS3 FlexBox弹性布局

可以看到one的宽度变成了two和three的两倍,因此flex item的尺寸和flex-grow的值成正比。

2. Flex Shrink

flex-grow相对的是flex-shrinkflex-shrink用于控制子元素尺寸超过flex container后,对子元素的压缩。请看示例:

修改box的宽度为flex container的1/3,one、two、three的flex-shrink分别为1,2,3:

.box{ height: 100px; width: 320px; }
.one{ background: pink; flex-shrink: 1; }
.two{ background: lightgreen; flex-shrink: 2; }
.three{ background: skyblue; flex-shrink: 3; }

当窗口正常尺寸时,效果如下:

10分钟理解CSS3 FlexBox弹性布局

当我们压缩窗口使其变得更窄后,效果如下:

10分钟理解CSS3 FlexBox弹性布局

当flex container宽度变为540px后,子元素都被不同程度的压缩了。压缩后的one、two、three的宽度分别为250px、180px、110px,所以相比于初始宽度320px被压缩掉的宽度分别为70px、140px、210px,70 : 140 : 210 = 1 : 2 : 3,与flex shrink的值成反比。实际上压缩率和flex item的初始尺寸也有关系,只不过当初始尺寸一样时它带来的影响被忽略了。

假设flex shrink为fs,flex item的初始尺寸为is,flex item被压缩的尺寸为ss,则正确的表达式为:

fs ∝ is/ss

3. Flex Basis

flex-basis用于设置flex item的初始宽/高。为什么有width和height还需要重新加一个flex-basis呢?flex-basis和width/height有如下的区别:

  1. flex-basis只能用于flex-item,而width/height可以应用于其他类型的元素;
  2. flex-basis和flex-direction有关,当flex-direction为row的时,flex-basis设置的是宽度,当flex-direction为column时,flex-basis设置的是高度;
  3. 当flex item被绝对定位后(absolute position),flex-basis不起作用,而width/height可以;
  4. flex-basis可以用于flex的简写形式,如:flex: 1 0 200px;

我们来看一下flex-basis的作用,将css修改如下:

.box{
  height: 100px;
  flex-grow: 1;
}
.one{
  background: pink;
  flex-basis: 100px;
}
.two{
  background: lightgreen;
  flex-basis: 200px;
}
.three{
  background: skyblue;
  flex-basis: 300px;
}

3个flex item都在原来的初始宽度基础上增加了相同的宽度:

10分钟理解CSS3 FlexBox弹性布局

当然,这个例子如果换成使用width也是一样的效果,但是虽然效果一样但意义不一样,所以使用flex布局时还是应该尽量遵守规范,选合适的人去干正确的事。

4. Order

通过order属性我们可以改变flex item的排列顺序,例如:

html:

<section id="blocks">
  <div class="one">1</div>
  <div class="two">2</div>
  <div class="three">3</div>
  <div class="four">4</div>
</section>

css:

#blocks{
  display: flex;
  margin: 10px;
  justify-content: space-between;
}

#blocks div{
  flex: 0 0 100px;
  padding: 40px 0;
  text-align: center;
  background: #ccc;
}

默认排列顺序是按照flex item在html中的出现顺序:

10分钟理解CSS3 FlexBox弹性布局

当我们修改flex item的order值后,flex item会按照order值升序排列:

css:

.one{ order: 4; }
.two{ order: 3; }
.three{ order: 2; }
.four{ order: 1; }

效果:

10分钟理解CSS3 FlexBox弹性布局

结语

flex就先简单介绍到这里,flex很强大也很简单,希望大家用的开心。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
前端制作动画的几种方式(css3,js)
Dec 12 HTML / CSS
利用CSS3的定位页面元素
Aug 29 HTML / CSS
纯CSS3发光分享按钮的实现教程
Sep 06 HTML / CSS
纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)
Apr 24 HTML / CSS
css3media响应式布局实例
Jul 08 HTML / CSS
利用CSS3动画实现圆圈由小变大向外扩散的效果实例
Sep 10 HTML / CSS
html5配合css3实现带提示文字的输入框(摆脱js)
Mar 08 HTML / CSS
html5实现多文件的上传示例代码
Feb 13 HTML / CSS
详解通过HTML5 Canvas实现图片的平移及旋转变化的方法
Mar 22 HTML / CSS
3种方式实现瀑布流布局小结
Sep 05 HTML / CSS
Html5实现首页动态视频背景的示例代码
Sep 25 HTML / CSS
css弧边选项卡的项目实践
May 07 HTML / CSS
详解如何在css3打包后自动追加前缀插件:autoprefixer
Dec 18 #HTML / CSS
CSS3田字格列表的样式编写方法
Nov 22 #HTML / CSS
纯css3实现思维导图样式示例
Nov 01 #HTML / CSS
CSS3 Flex 弹性布局实例代码详解
Nov 01 #HTML / CSS
CSS3 创建网页动画实现弹跳球动效果
Oct 30 #HTML / CSS
css3实现椭圆轨迹旋转的示例代码
Oct 29 #HTML / CSS
纯css3实现宠物小鸡实例代码
Oct 08 #HTML / CSS
You might like
PHP的类 功能齐全的发送邮件类
2006/10/09 PHP
php中explode与split的区别介绍
2012/10/03 PHP
解析PHP中的内存管理,PHP动态分配和释放内存
2013/06/28 PHP
PHP中file_get_contents函数抓取https地址出错的解决方法(两种方法)
2015/09/22 PHP
Laravel SQL语句记录方式(推荐)
2016/05/26 PHP
Laravel5.5 数据库迁移:创建表与修改表示例
2019/10/23 PHP
如何将网页表格内容导入excel
2014/02/18 Javascript
jQuery的context属性用法实例
2014/12/27 Javascript
NodeJS使用jQuery选择器操作DOM
2015/02/13 NodeJs
简单的JS时钟实例讲解
2016/01/13 Javascript
分步解析JavaScript实现tab选项卡自动切换功能
2016/01/25 Javascript
一道面试题引发的对javascript类型转换的思考
2017/03/06 Javascript
jQuery插件FusionCharts绘制的3D双柱状图效果示例【附demo源码】
2017/04/20 jQuery
JavaWeb表单及时验证功能在输入后立即验证(含用户类型,性别,爱好...的验证)
2017/06/09 Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
2017/12/27 Javascript
微信小程序6位或多位验证码密码输入框功能的实现代码
2018/05/29 Javascript
Vue实现跑马灯效果
2020/05/25 Javascript
vue中是怎样监听数组变化的
2020/10/24 Javascript
[00:43]FTP典藏礼包 DOTA2三大英雄霸气新套装
2014/03/21 DOTA
[05:31]DOTA2上海特级锦标赛主赛事第三日RECAP
2016/03/05 DOTA
windows下安装python paramiko模块的代码
2013/02/10 Python
Python脚本实现下载合并SAE日志
2015/02/10 Python
使用Python和xlwt向Excel文件中写入中文的实例
2018/04/21 Python
django认证系统实现自定义权限管理的方法
2018/07/16 Python
如何使用python切换hosts文件
2020/04/29 Python
手把手教你如何用Pycharm2020.1.1配置远程连接的详细步骤
2020/08/07 Python
CSS3实现大小不一的粒子旋转加载动画
2016/04/21 HTML / CSS
美国紧身牛仔裤品牌:NYDJ
2017/05/24 全球购物
荷兰在线啤酒店:Beerwulf
2019/08/26 全球购物
财务支持类个人的自我评价
2014/02/14 职场文书
优秀少先队辅导员先进事迹材料
2014/05/18 职场文书
园林系毕业生求职信
2014/06/23 职场文书
中学生自我评价范文
2015/03/03 职场文书
使用Oracle跟踪文件的问题详解
2021/06/28 Oracle
MySQL 中如何归档数据的实现方法
2022/03/16 SQL Server
pycharm无法安装cv2模块问题
2022/05/20 Python