早之前有所了解,现在有时间整理一下,跟大家分享学习。

虽然Flex布局09年就被W3C所提出,但是目前浏览器支持上还不是很好,网上找的一张图片,仅供参考:

我们先从简单讲起。如果仅仅只想实现一个栅格布局,没必要引入一个复杂的框架(如bootstrap),短短几行代码也能实现该功能。

例子:有个父div,三个子div,宽度比是1:2:1,以下代码:

<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
* {
box-sizing: border-box;
}
body {
padding: 20px;
}
.flex{
display:flex;
}
.flex div{
text-align: center;
}
.one{
background: blue;
flex:1;
}
.two{
flex:2;
background: yellow;
}
</style>
</head>
<body>
<div class="flex">
<div class="one">one</div>
<div class="two">two</div>
<div class="one">one</div>
</div>
</body>
</html>

显示如下:

解读:把父div设置为display:flex;后,它的所有子元素自动成为容器成员。同时,所有的子元素的float、clear、vertical-align都会失效。子元素有个属性flew,其实接受的是3个值,分别是flex-grow,flex-shrink,flex-basis,后两个属性选填(这里用不上便不填,后面再做介绍),flex-grow:定义当前子元素的比例。

Q:如果我想要列与列之间有等距间隔怎么办?

A:你可以添加 margin 到列上。你也可以添加 padding 到列上。当然父div有个宽度补齐(justification)的属性也可以实现。

代码稍作修改:

<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
* {
box-sizing: border-box;
}
body {
padding: 20px;
}
.flex{
display:flex;
justify-content: space-between;
}
.flex div{
text-align: center;
}
.one{
background: blue;
width: 23%;
}
.two{
background: yellow;
width:48%;
}
</style>
</head>
<body>
<div class="flex">
<div class="one">one</div>
<div class="two">two</div>
<div class="one">one</div>
</div>
</body>
</html>

显示如下:

解读:稍作介绍下justify-content属性。它定义子元素在主轴上的对齐方式,一共有5个值:

flex-start(默认值):左对齐

flex-end:右对齐

center:居中

space-between:两端对齐,子元素之间的间隔都相等

space-around:每个子元素两侧的间隔都相等,所以就会形成子元素与子元素之间的间隔是子元素与两端之间的间隔的2倍

以上是一些简单的用法,下面想详细的记录下flex的其他用法,跟大家分享,不对之处请多多指出。

—————————————————————————————————分割线—————————————————————————————————————

将一个容器(为避免混淆,暂称父元素)设置display为flex后,父元素便拥有以下属性:

1、flex-direction:决定子元素的排列方向。

row: 默认值,水平方向排列,起点在左边。

row-reverse:水平方向排列,起点在右边。

column:垂直方向,起点在上沿。

column-reverse:垂直方向,起点在下沿。

2、flex-wrap:定义一行排不下时如何换行。

nowrap(默认):不换行。

wrap:换行,第一行在上方。

wrap-reverse:换行,第一行在下方。

3、flex-flow:flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。

4、justify-content:前面已经介绍,忘记了请往前看。

5、align-items:还记得flex-direction吗,这个属性类似于定义子元素在垂直方向上面的对齐方式。

先来段代码:

<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
}
.flex div{
text-align: center;
}
.one{
background: blue;
flex:1;
}
.two{
background: yellow;
flex:2;
}
</style>
</head>
<body>
<div class="flex">
<div class="one"><p></p>one1</div>
<div class="two">two</div>
<div class="one">one2</div>
</div>
</body>
</html>

(此时子元素并没设置高度以及父元素没有设置align-items当然是按照默认值显示)

1)stretch(默认值):如果子元素未设置高度或设为auto,将占满整个容器的高度。

修改css

.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
align-items:flex-start;
}
.one{
background: blue;
flex:;
height: 50px;
}
.two{
background: yellow;
flex:;
height: 100px;
}

2)flex-start:上沿对齐。

3)flex-end:下沿对齐。

4)center:居中对齐。

5)baseline: 子元素的第一行文字的基线对齐。

子元素有以下属性:

1、order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。

.one{
background: blue;
flex:;
order:;
}
.two{
background: yellow;
flex:;
}

2、flex-grow:定义当前子元素的比例,比如上面one比例是1,two比例是2。

3、flex-shrink:可选属性。属性定义了子元素的缩小比例,默认为1,即如果空间不足,该子元素将缩小。如果所有子元素的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个子元素的flex-shrink属性为0,其他子元素都为1,则空间不足时,属性为0的不缩小,负值对该属性无效。

4、flex-basis:可选属性。定义分配空间前,该子元素的宽度。默认值auto,可设置固定值(如100px),设置后该子元素将占据固定空间。

.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
}
.one{
background: blue;
flex-basis:80px;
}
.two{
background: yellow;
flex:;
}

5、简写的flex属性。flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。

6、align-self:align-self属性允许单个子元素有与其他子元素不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。

<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
align-items:center;
}
.one{
background: blue;
flex:1;
height: 50px;
}
.two{
background: yellow;
flex:2;
height: 100px;
align-self:flex-end;
}
.flex div{
text-align: center;
}
</style>
</head>
<body>
<div class="flex">
<div class="one">one1</div>
<div class="two">two</div>
<div class="one">one2</div>
</div>
</body>
</html>

———————————————————————————————分割线——————————————————————————————————

学以致用,我们来用Flex布局实现圣杯布局

要实现的效果:上中下三块,其中中间一块为左中右,左右等宽,中间占其余宽度。

<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
*{
padding:0;
margin:0;
}
html,body{
width: 100%;
height: 100%;
}
.main{
width:100%;
height:100%;
display: flex;
flex-direction: column;
}
.header,.footer{
flex: 1;
background: yellow;
}
.middle{
flex: 5;
display:flex;
}
.center{
flex: 1;
background: #ccc;
}
.left,.right{
background:green;
flex: 0 0 100px;
}
.left{
order: -1;
}
</style>
</head>
<body>
<div class="main">
<div class="header"></div>
<div class="middle">
<div class="center"></div>
<div class="left"></div>
<div class="right"></div>
</div>
<div class="footer"></div>
</div>
</body>
</html>

分享完毕,欢迎转载,请注明出处!

参考链接:http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html?utm_source=tuicool

探讨弹性布局Flexible Box的更多相关文章

  1. 弹性布局 Flexible Box

    页面中任何一个元素都可以指定为 弹性布局(Flex) 属性:display 取值: 1.flex     将块级元素变为弹性布局容器 2.inline-flex   将行内元素变为弹性布局容器 兼容性 ...

  2. CSS:CSS弹性盒子布局 Flexible Box

    一.简介 flexbox:全称Flexible Box, 弹性盒子布局.可以简单实现各种伸缩性的设计,它是由伸缩容器和伸缩项目组成.任何一个元素都可以指定为flexbox布局.这种新的布局方案在200 ...

  3. 简单探讨弹性布局flex

    css 弹性布局: 盒子模型: box-sizing属性1.content-box 正常的普通的盒子模型用padding和border会使盒子变大:(向外扩张)2.border-box 盒子模型,pa ...

  4. Flex box弹性布局 及 响应式前端设计的优化

    Flex box弹性布局 Flex box是CSS3新添加的一种模型属性,它的出现有力的打破了我们常常使用的浮动布局.实现垂直等高.水平均分.按比例划分,可以实现许多我们之前做不到的自适应布局.如果你 ...

  5. css3 弹性布局和多列布局

    弹性盒子基础 弹性盒子(Flexible Box)是css3中盒子模型的弹性布局,在传统的布局方式上增加了很多灵活性. 定义一个弹性盒子 在父盒子上定义display属性: #box{ display ...

  6. 第10章 布局样式相关-伸缩布局(Flexible Box)

    伸缩布局(一) CSS3引入了一种新的布局模式--Flexbox布局,即伸缩布局盒模型(Flexible Box),用来提供一个更加有效的方式制定.调整和分布一个容器里项目布局,即使它们的大小是未知或 ...

  7. CSS3 Flex Box 弹性盒子、弹性布局

    目录 1. 概要 2. justify-content 属性 3. align-items 属性 4. flex-wrap 属性 5. align-content 属性 6. 居中 7. align- ...

  8. CSS3弹性伸缩布局(一)——box布局

    CSS3弹性伸缩布局简介 2009年,W3C提出了一种崭新的方案----Flex布局(即弹性伸缩布局),它可以简便.完整.响应式地实现各种页面布局,包括一直让人很头疼的垂直水平居中也变得很简单地就迎刃 ...

  9. CSS3伸缩盒Flexible Box

    这是一种全新的布局,在移动端非常实用,IE对此布局的相关的兼容不是很好,Firefox.Chrome.Safrai等需要加浏览器前缀. 先说说这种布局的特点: 1)移动端由于屏幕宽度都不一样,在布局的 ...

随机推荐

  1. Smarty模板的基础

    对前后端进行分离 如果要用的话,要从网上把smarty文件下载下来,才能用 smarty的核心是一个类 建一个php文件,写一个类文件 <?php class smarty { public $ ...

  2. MySQL基础语句与其在Python中的使用

    一.MySQL基础语句 $ mysql -u root -p (有密码时) $ mysql -u root     (无密码时) QUIT (or \q)  退出 查看当前所有数据库 show dat ...

  3. 关于Xmanager使用问题的总结

    做大数据的人对Xmanager这类远程连接工具应该都不陌生,我在使用Xmanager时遇到了一些问题并经过google和亲测解决,写在这里与大家分享. 1. [问题描述] 在windows上使用Xma ...

  4. Cocos2d-x shader学习2: 模糊(Blur)

    模糊效果在游戏中经常会用到,有的为了突出前景会把背景给模糊化,有的是因为一些技能需要模糊效果.模糊是shader中较为简单的一种应用.cocos2dx 3.x给的demo中,就有sprite的模糊的效 ...

  5. TokuDB性能测试报告

    一 .背景介绍 近年来,TokuDB作为MySQL的大数据(Big Data)存储引擎受到人们的普遍关注.其架构的核心基于一种新的叫做分形树(Fractal Trees)的索引数据结构,该结构是缓存无 ...

  6. 九度oj题目1207:质因数的个数

    题目描述: 求正整数N(N>1)的质因数的个数. 相同的质因数需要重复计算.如120=2*2*2*3*5,共有5个质因数. 输入: 可能有多组测试数据,每组测试数据的输入是一个正整数N,(1&l ...

  7. SEO-长尾词与分词技术

        长尾关键词与分词技术 长尾关键词:网站非目标关键词,能给网站带来流量的关键词. 例如:主关键词是成都网站建设 那么,跟成都网站建设相关的词,就叫做长尾关键词. 比如:成都网站建设哪里好?成都网 ...

  8. MVC+Spring.NET+NHibernate .NET SSH框架整合

    在JAVA中,SSH框架可谓是无人不晓,就和.NET中的MVC框架一样普及.作为一个初学者,可以感受到.NET出了MVC框架以后太灵活了(相比之前的web Form),嗯,关于.NET中的MVC框架我 ...

  9. Webpack单元测试,e2e测试

    此篇文章是续 webpack多入口文件.热更新等体验,主要说明单元测试与e2e测试的基本配置以及相关应用. 一.单元测试 实现单元测试框架的搭建.es6语法的应用.以及测试覆盖率的引入. 1. 需要安 ...

  10. js模块化加载器实现

    背景 自es6以前,JavaScript是天生模块化缺失的,即缺少类似后端语言的class, 作用域也只以函数作为区分.这与早期js的语言定位有关, 作为一个只需要在网页中嵌入几十上百行代码来实现一些 ...