转自:http://www.360doc.com/content/14/0811/01/2633_400926000.shtml

display:flex 多栏多列布局浏览器支持情况:火狐直接支持w3c无前缀写法,谷歌和opera支持-webkit- 前缀写法,比较适合移动端开发使用,

display:flex 这个牛逼的css3布局属性,遗憾的是只有谷歌和火狐支持,
中国人常用的手机上的浏览器几乎全军覆没,UC浏览器不支持,安卓4.1.1和之前版本手机自带的浏览器也不支持,微信自带浏览器也不支持。

看来要留给儿子们用了。

示例:

html,body{ padding:0; margin:0;}
/*flex-flow: row wrap; row横向(左向右)显示 column竖向(上向下)显示 wrap一行显示不完的时候换行
*/
.col{ border:red solid 1px;}
footer { height:300px;display: -webkit-flex;-webkit-flex-flow: row;-webkit-align-items: stretch;-webkit-justify-content:space-between;/*IE10还不支持*/display: -ms-flex;-ms-flex-flow: row wrap;-ms-align-items: stretch;-ms-justify-content:space-between;display: flex;flex-flow: row;align-items: stretch;justify-content:space-between;
}
.col2{-webkit-flex:1;-moz-flex:1;flex:1}
display:flex 的HTML测试结构<footer><div class="col col1" style=" width:60px;">jquery特效</div><div class="col col2" style="">前端路上</div><div class="col col3" style="width:30px;">懒人建站</div>
</footer> 

一个Flexbox布局是由一个伸缩容器(flex containers)和在这个容器里的伸缩项目(flex items)组成。

  伸缩容器(flex  containers)是一个HTML标签元素,并且“display”属性显式的设置了“flex”属性值。在伸缩容器中的所有子元素都会自动变成伸缩项目(flex  items)。
  这有一个三列布局的例子。外面的div容器是一个伸缩容器,而里面的left、main和right三个div都是伸缩项目:

  设置一个简单的伸缩容器很容易,代码如下:

.container {  display: flex;}          伸缩方向与换行(flex-flow)
  伸缩容器有一个CSS属性“flex-flow”用来决定伸缩项目的布局方式。如果伸缩容器设置了“flex-flow”值为“row”,伸缩项目排列由左向右排列:

  如果“flex-flow”值设置为“column”,伸缩项目排列由上至下排列:

这里将展处样设置伸缩容器,使用伸缩项目在一行中显示:

.container {  display: flex;  flex-flow: row;}          一个伸缩容器中的所有伸缩项目既可以排列在单行也可以多行排列。这个主要由“flex-flow”是否设置为“wrap”来决定。如果伸缩容器设置了“wrap”属性值,当伸缩项目在伸缩容器中无法在一行中显示的时候会另起一行排列。

这里展示了如何将伸缩容器设置为“wrap”:

.container {  display: flex;  flex-flow: row wrap;}  伸缩项目(flex items)
  在伸缩容器中的所有子元素都将自动变成伸缩项目。没有额外配置CSS的必要。你唯一需要的做的就是设置伸缩项目的尺寸。
  如果伸缩容器把“flex-flow”设置为“row”后,伸缩项目将需要设置他们的宽度。伸缩项目的高度将会自动设置为伸缩容器的高度:

 如果伸缩容器把“flex-flow”设置为“column”后,伸缩项目将需要设置他们的高度,伸缩项目的宽度将会自动设置为伸缩容器的宽度:

 给伸缩项目设置“width”和“height”属性来定义伸缩项目尺寸,而这个伸缩项目是独立于其他伸缩项目。例如,如果我们给主内容(content)设置了一个600px的宽度,不管伸缩容器中有一个、两个或者上百个伸缩项目,主内容的宽度都是600px。

  如果你想伸缩项目根据伸缩容器剩余的空间来决定伸缩项目的宽度,你可以使用“flex”属性。例如,我们可以告诉浏览器,左边栏和右边栏占用了伸缩容器减去主内容宽度的空间。
  flex的值于对应的空间成正比。如果左边栏设置了值为“1”和右边栏设置了值为“2”,伸缩容器剩余的空间将按比例分配给左边栏和右边栏,并且右边栏所占的空间是左边栏的两倍:

  下面是示例中运用在伸缩项目上的一些代码,展示了独立宽度和按比例计算的宽度:

.main {  width: 600px;}.left {  flex: 1;}.right {  flex: 2;}  完整的实例
  这是一个很简单的实例,Flexbox创建了一个经典的三列布局。主内容宽度为60%,而边栏是使用“flex”属性,按比例自动根据伸缩容器剩余空间计算得到对应的宽度:
  HTML结构
  …       …     …
          CSS代码
.container {  display: flex;  flex-flow: row;}.main {  width: 60%;}.left {  flex: 1;}.right {  flex: 2;}  示例效果

转载于:https://www.cnblogs.com/y-lin/p/5728442.html

display:flex 多栏多列布局相关推荐

  1. 土旦:关于display:flex碰上white-space nowrap 影响布局的问题

    背景,做一个前面图片宽度固定,后面宽度自适应,使用到了flex布局,但是想让后面div里文字不换行,超出以点点表示时,这时布局就乱了,查了下,原来flex布局与white-space:nowrap有影 ...

  2. CSS3多列布局 columns 弹性布局 flex

    多列布局columns 多列布局可以控制页面内容的排版方式,可以将文本内容设计成像报纸一样的多列布局. 属性 示例 含义 column-count column-count: 3; 将元素内部分割成3 ...

  3. div布局、table布局、flex布局、多列布局、网格布局 示例

    目录 基础代码 demo.html css/common.css div实用布局示例 代码 效果图 table布局 代码 效果图 flex布局 代码 效果图 多列布局 代码 效果图 网格布局 代码 效 ...

  4. java窗口三栏布局_移动端的flex三栏布局的相关知识介绍(代码示例)

    本篇文章给大家带来的内容是关于移动端的flex三栏布局的相关知识介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 默认情况下先显示移动端,通过 @media 属性适配屏 ...

  5. 当display:flex弹性布局与position:absolute/fixed定位一起用,会出现的问题与解决方法

    首先放出使用场景的截图: 使用场景 导航栏固定定位 导航栏内,平均分为四块,为了适配各种移动设备,使用了flex布局. 与此同时,产品经理要求:页面上滚越过封面图时,导航栏变为固定定位,浮在页面顶部. ...

  6. 前端歌谣的刷题之路-第一百四十五题-双列布局-flex

    前言 我是歌谣 我有个兄弟 巅峰的时候排名c站总榜19 叫前端小歌谣 曾经我花了三年的时间创作了他 现在我要用五年的时间超越他 今天又是接近兄弟的一天人生难免坎坷 大不了从头再来 歌谣的意志是永恒的 ...

  7. flex两列布局 以及三列布局

    flex两列布局 左固定右适应: <div class="a"><div class="a1"></div><div ...

  8. display flex布局

    目录 calc()语法 column 列(兼容性一般般,用的较少) Flex 布局 justify-content属性 align-items 交叉轴 flex-direction属性 flex-wr ...

  9. 页面布局-----display:flex详解

    简介: display:flex是一种布局方式.它即可以应用于容器中,也可以应用于行内元素.是W3C提出的一种新的方案,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持. ...

最新文章

  1. 鸿蒙升级名单确认最新,华为鸿蒙系统升级名单正式确认!全面替换安卓:流畅度比肩iOS...
  2. java编译器 Javac 编译原理
  3. asp.net 截屏 截取web页面 源代码
  4. 华为HCNE专题一:网络基础知识
  5. 046、JVM实战总结:动手实验:自己动手模拟出对象进入老年代的场景体验一下(下)
  6. HTML、CSS、JS对unicode编码字符的规则
  7. 颜色和心理年龄测试软件,超准的色彩心理学:选8个颜色,就可以测出你的心理年龄...
  8. git 设置全局代理_git 代理配置
  9. JetBrains Resharper VS2017 破解方法(License Server 破解方法)
  10. 真没想到!时隔3年,被废掉武功的快播,依然是最受欢迎的播放器
  11. j2me之诺基亚S40模拟器
  12. 机器学习-推荐系统中基于深度学习的混合协同过滤模型
  13. hdu 5442 Favorite Donut 后缀数组
  14. element -UI升级,使用el-tabs导致浏览器卡死问题
  15. python输入素数为什么要先判断是否是素数再用欧拉筛法
  16. Kafka(生产者)
  17. Delphi7企业原版_史上最经典的delphi 版本
  18. Windows10系统CUDA和CUDNN安装教程
  19. OpenBLT的介绍、应用场景及开源许可
  20. 祝福语大全 计算机,【一到十的祝福语】 从一到十的祝福语_一到十祝福语大全_东城教研...

热门文章

  1. Algorithm, Secret key and Protocol
  2. AndFix解析——(中)
  3. JZOJ 5574. 【NOI2018模拟3.10】占领
  4. 服务器电源can协议,硬件接口协议之“CAN总线EMC设计”
  5. db2 删除索引_MySQL 选错索引的原因是什么?
  6. JAVA报错是一层一层的吗_Java异常处理:给程序罩一层保险
  7. 关于python pdb的描述_The python debugger(PDB)的简介
  8. 服务器是什么系统_为什么视频监控系统搭建,要使用流媒体服务器做视频分发?...
  9. linux根据pid查看进程,linux根据pid获取进程名和获取进程pid(c语言获取pid)
  10. java并发编程实践_Java并发编程实践如何正确使用Unsafe