前端布局一直是CSS的一个重点应用,然而基于盒子模型的传统布局方案,依赖display + position + float 属性,对于某些特殊的布局非常不方便,比如:垂直居中就不容易实现。针对这一情况,在2009年,W3C提出了一种新的方案:Flex布局,可以简便、完整、响应式地实现前端的各种布局,并且已经得到几乎所有浏览器的支持。

众所周知,前端分为PC端和移动端,并且它们的界面布局有一些差别,比如:PC端的界面中,水平方向是主轴(main axis),竖直方向是交叉轴(cross axis);而移动端,水平方向是交叉轴(cross axis),竖直方向是主轴(main axis),针对这一差别,在前端布局中要特别注意。

flex属性简介

flex的属性分为两类:父容器属性和子item的属性

父容器属性

属性 作用 特性分类
flex-direction 定义子项在容器内的排列方向 排列
flex-wrap 定义子项在容器内的换行效果 排列
flex-flow flex-direction和flex-wrap的复合属性 排列
justify-content 定义子项在容器内水平对齐方式 对齐
align-items 定义子项在容器内垂直对齐方式 对齐
align-content 定义多行子项在容器内整体垂直对齐方式 对齐

子item属性

属性 作用 特性分类
order 定义子项们的排列顺序 排列
flex-grow 定义子项宽度之和不足父元素宽度时,子项拉伸的比例 占地面积
flex-shrink 定义子项宽度之和超过父元素宽度时,子项缩放的比例 占地面积
flex-basis 定义子项的初始宽度,flex-grow和flex-shrink以此为基础缩放 占地面积
align-self 定义单个子项与其他项目不一样的对齐方式 对齐

Flex布局

FlexFlexible Box的缩写,意思是弹性布局,用来为盒子模型提供最大的灵活性。分为两种布局方式:flexinline-flex

1. flex: 将对象作为弹性伸缩盒显示

flex默认从左边开始布局,所以指定宽度后,子item就开始从左至右依次布局

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Test</title>
<style type="text/css">
.main{
width:200px;
background-color: red;
display: flex;/*父div设置该属性*/
}
.main>div{
width: 50px;
height: 50px;
border: 1px solid blue;
box-sizing: border-box;/*这是css3属性,如果不懂,请继续往下阅读*/
/*float:left;这个属性就不需要了,会自动浮动*/
}
</style>
</head>
<body>
<div class="main">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
</body>
</html>

效果图

2. inline-flex:将对象作为内联块级弹性伸缩盒显示

inline-flex将对象作为内联级容器,它会根据子item的大小自适应宽度和高度,所以可以删除width: 200px

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Test</title>
<style type="text/css">
.main{
background-color: red;
display: inline-flex;/*父div设置该属性*/
}
.main>div{
width: 50px;
height: 50px;
border: 1px solid blue;
box-sizing: border-box;/*这是css3属性,如果不懂,请继续往下阅读*/
/*float:left;这个属性就不需要了,会自动浮动*/
}
</style>
</head>
<body>
<div class="main">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
</body>
</html>

效果图

flex父容器属性

1. flex direction

控制主轴的方向,即子item的排列方向,有四个取值范围:

  • row(default)- 主轴水平
  • row-reverse
  • column - 主轴垂直
  • column-reverse

2. flex wrap

定义子item在主轴方向的换行效果

3. flex-flow

该属性是flex-directionflex-wrap两个属性的缩写,默认值为:row nowrap

4. justify content

定义子item在主轴方向的对齐方式

5. align-items

定义子item在交叉轴方向的对齐方式

6. align-content

定义多行子item在交叉轴上的对齐方式

子item属性

1. order

定义子item的排列顺序,默认为0

2. flex-grow

定义子item的宽度小于父容器时,子item的拉伸比例,默认为0,表示不拉伸

3. flex-shrink

定义子item的宽度之和超过父容器时,子item的缩放的比例,默认为1

4. flex-basis

设置子item的宽度flex-direction = row)或高度flex-direction = column)。如果设置该属性,那么flex-grow/flex-shrink以该属性大小进行缩放

5. flex

该属性是:flex-grow flex-shrink flex-basis的简写,默认值为:0 1 auto,其中后两个属性可选

6. align-self

定义单个子item在交叉轴上的对齐方式,会覆盖默认的对齐方式。默认值为auto,表示继承父容器的align-items属性,如果没有父容器,则等同于stretchstretch: 伸缩项目在交叉轴方向占满伸缩容器, 前提是不设置交叉轴方向的尺寸)

定位

display属性定义子item如何在父容器内布局,有两中类型:relativeabsolute

1. display: relative

在相对定位中,布局子item时需要用到marginborderpadding等盒子模型。其中,borderpadding会显示在item的背景色中;而margin则不会,默认是透明色

2. display: absolute

使用绝对定位的item,如果其父容器设置了relative布局,则以父容器做参考,如果父容器不设置relative布局,则以window做参考。其中,设置布局的属性为:left、right、top、bottom、start、end

Position = Absolute; Start = 0; Top = 0; Width = 50; Height = 50;

视图:

Position = Absolute; Start = 10; Top = 10; End = 10; Bottom = 10;

视图:


至此,Flexbox的语法介绍完毕,虽然有点多,但是还要多练,熟能生巧,熟练后你会发现,前端flex布局快速、高效和灵活。

(部分图片来源互联网,如有侵权,请告知,我怕赔不起)

参考文章

https://www.w3.org/TR/css-flexbox-1/#flex-formatting-context

https://facebook.github.io/yoga/docs/absolute-position/

http://www.cnblogs.com/shuiyi/p/5716918.html

http://www.w3school.com.cn/css/css_boxmodel.asp

http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

https://my.oschina.net/sheila/blog/384806

前端布局之Flex语法的更多相关文章

  1. 【前端】Flex 布局教程:语法篇 [转]

    网页布局(layout)是 CSS 的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂 ...

  2. Flex 布局教程:语法和实例

    语法篇 网页布局(layout)是 CSS 的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性.它对于那些特殊布局非常不方便, ...

  3. Flex 布局教程:语法篇

    作者: 阮一峰 网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便 ...

  4. Flex 布局教程:语法篇[转]

    网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  5. Flex 布局教程:语法篇(转)

    网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  6. [转]Flex 布局教程:语法篇

    网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  7. CSS学习笔记(11)--Flex 布局教程:语法篇

    原文--阮一峰博客 作者: 阮一峰 日期: 2015年7月10日 网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 ...

  8. 一、flex布局教程:语法篇

    本文转自阮一峰大师的教程,此处做记录,方面后面自己学习使用~   布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便 ...

  9. Flex 布局教程:语法篇 【转】

    Flex 布局教程:语法篇   作者: 阮一峰 日期: 2015年7月10日 原文:http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html 网 ...

随机推荐

  1. [图形学] Chp8.7.2 梁友栋-Barsky线段裁剪算法

    这节简单介绍了梁友栋-Barsky裁剪算法的原理,只有结论并没有过程,看过http://blog.csdn.net/daisy__ben/article/details/51941608这篇文章后,大 ...

  2. BufferedWriter

    package JBJADV003;import java.io.*;public class BufferedWriterTest { public static void main(String[ ...

  3. Struts2的知识点小总结

    strust2是 struts1和webwork的结合  (本质相当于servlet) 核心:拦截器 interceptor  action ognl和valuestack 使用struts的准备工作 ...

  4. Chrome浏览器扩展开发系列之十三:消息传递Message

    由于content scripts运行在Web页面的上下文中,属于Web页面的组成部分,而不是Google Chrome扩展程序.但是content scripts又往往需要与Google Chrom ...

  5. hightcharts在移动端运用 FastClick后苹果上legend点击失效的解决办法

    问题:在移动端做图表运用了hightcharts,引用了fastclick来消除300ms的延迟,但是发现苹果(安卓正常)上hightcharts的legend点击不起作用了,必须长按才行. 使用fa ...

  6. Go学习笔记(二)十分钟上手

    加 Golang学习 QQ群共同学习进步成家立业工作 ^-^ 群号:96933959 变量&常量 变量 变量名由字母.数字.下划线组成,不能以数字开头. ... var ( A int //默 ...

  7. Go语言学习笔记(三)数组 & 切片 & map

    加 Golang学习 QQ群共同学习进步成家立业工作 ^-^ 群号:96933959 数组 Arrays 数组是同一种数据类型的固定长度的序列. 数组是值类型,因此改变副本的值,不会改变本身的值: 当 ...

  8. 使用Nginx+CppCMS构建高效Web应用服务器(之三)

    使用Nginx+CppCMS构建高效Web应用服务器(之三) --充分利用服务器和客户端计算能力 欢迎测试,攻击:http://www.litelottery.com     网页右上角,选择博彩,演 ...

  9. 树状数组(瞎bb) [树状数组]

    Copyright:http://www.cnblogs.com/ZYBGMZL/ 树状数组是一个利用一维数组和位运算组成的求解区间问题的高效数据结构,其构造如图所示 首先,我们要用它解决单点修改.区 ...

  10. SQL Server 数据库表的管理

    上一篇文章简单梳理了一下SQL Server数据库的安装和基本操作,这篇文章主要讲述一下数据库表的管理 一.数据库的创建 有关数据库的创建有两种方式,一种是通过视图创建,第二种就是通过T-SQL语句来 ...