flex的一些属性

CSS3中引入了另一种框--flexbox,flexbox有一些block和inline不同的性质,比如:

  1. 自适应子元素(flex item,又称伸缩项目)的宽度
  2. 伸缩项目的float,clear,vertical-align属性失效
  3. 不能继承flex框,但可以依次设置
  4. 可以修改flex流的方向以及布置规则

现在就大体讲述下这个具体属性的表示含义。

设置flexbox的兼容性

将一个容器设置为flexbox(又称伸缩容器)很简单,但是却存在一些兼容性的问题,比如在IE10下,早期的webkit系列中,都与标准有一些差异,但是我们可以通过less预处理器避免手动输入这些重复的代码。

.flexbox() {
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
}

flex-flow属性介绍

flex-flow设置flex流的方向(主轴的方向)以及伸缩项目如何换行,具体对应的属性是flex-direction和flex-wrap。flex-direction设置main-axis(主轴)的方向,可选参数为row,row-reverse,column,column-reverse,顾名思义,当方向为row时,伸缩项目横向排列,若此时所有伸缩项目的宽度已经超出了伸缩容器的宽度,浏览器就需要根据flex-wrap属性来布局。若flex-wrap:wrap,则换行放置,若为flex-wrap:nowrap,则所有伸缩项目放在同一行内。

flex-flow是这两个属性的结合,设置方式为flex-flow: row wrap;

justify-content属性介绍

justify-content用来设置伸缩项目在主轴上的排列方式。justify-content有一些参数:flex-start、flex-end、center、space-between、space-around。具体的区别可以通过测试可知。

align-items属性介绍

该属性设置伸缩项目在侧轴(垂直于主轴方向)方向如何放置。和justify-content类似,可以取flex-start,center,flex-end和stretch属性。stretch可以将所有的伸缩项目拉伸至等高高度,并充满伸缩容器。

order属性介绍

order属性可以改变伸缩项目的显示顺序,可以方便的修改布局的相对位置。order值越小,布局位置越靠前。order也有兼容性的问题,可以在less下这样设置

.order(@val) {
-webkit-box-ordinal-group: @val;
-moz-box-ordinal-group: @val;
-ms-flex-order: @val;
-webkit-order: @val;
order: @val;
}

伸缩项目中flex属性介绍

flex是一个综合属性设置,包括了flex-grow、flex-shrink、flex-basis。

  1. flex-grow属性值为正数值,用来设置扩展比率,也就是剩余空间是正值的时候此伸缩项目相对于伸缩容器里其他伸缩项目能分配到空间比例。若省略则会被设置为“1”。
  2. flex-shrink属性值为正数值,用来设置收缩比率,也就是剩余空间是负值的时候此伸缩项目相对于伸缩容器里其他伸缩项目能收缩的空间比例。若省略则会被设置为“1”,在收缩的时候收缩比率会以伸缩基准值加权。
  3. flex-basis与width属性使用相同的值,可以用来设置flex-basis长写并指定伸缩基准值,也就是根据可伸缩比率计算 出剩余空间的分布之前,伸缩项目主轴长度的起始数值。若在flex缩写省略了此属性设置,则flex-basis的指定值是“0”,若flex-basis的指定值是“auto”,则伸缩基准值的指定值是元素主轴长度属性的值。

flex也有一些缩写值,如flex:auto和flex:initial。其中,flex:auto === flex:1 1 auto;flex:initial === flex: 1 0 auto;当flex-basis设置为0时,意味着将按照flex-grow的比例分配所有空间。

具体可以通过 w3c文档 查看。

flex属性也有兼容性问题,依然使用less解决:

.flex(@flex-grow,@flex-shrunk,@flex-basis) {
-webkit-box-flex: @arguments;
-moz-box-flex: @arguments;
-webkit-flex: @arguments;
-ms-flex: @arguments;
flex: @arguments;
}

示例

现在使用h5标签构建一个响应式布局,使用flex模型和媒体查询。

.flexbox() {
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
} .flex(@flex-grow,@flex-shrunk,@flex-basis) {
-webkit-box-flex: @arguments;
-moz-box-flex: @arguments;
-webkit-flex: @arguments;
-ms-flex: @arguments;
flex: @arguments;
} .order(@val) {
-webkit-box-ordinal-group: @val;
-moz-box-ordinal-group: @val;
-ms-flex-order: @val;
-webkit-order: @val;
order: @val;
} html{
-webkit-text-size-adjust:none;
font-size: 10px;
}
.wrapper{
background: tomato;
.flexbox;
flex-flow: row wrap;
}
.main-header{
.flex(1,1,100%);
font-weight: bold;
font-size: 40px;
color:#ffffff;
text-align: center;
height:100px;
line-height: 100px;
background: blueviolet;
}
.main-content{
.flex(2,1,60%);
width:60%;
font-size: 14px;
.order(2);
height:300px;
background: #ffffff;
line-height:20px;
}
.nav{
.flex(1,1,20%);
width:20%;
.order(1);
background: greenyellow;
ul{
list-style: none;
margin:;
padding:;
overflow: hidden;
background: deepskyblue;
li{
float: left;
width:100%;
padding: 10px;
border-top: 1px solid rgba(255,255,255,0.3);
border-bottom: 1px solid rgba(0,0,0,0.1);
text-align: center;
height: 100%;
&:hover{
background: darken(deepskyblue, 2%);
}
a{
text-decoration: none;
color: #ffffff;
font-size: 14px;
display: block;
height: 100%;
cursor: pointer;
}
}
}
}
.sec{
.flex(1,1,20%);
width:20%;
.order(3);
font-weight: bold;
font-size: 40px;
color:#ffffff;
text-align: center;
background: #000000;
}
.main-footer{
.flex(1,1,100%);
.order(4);
font-weight: bold;
font-size: 40px;
color:#ffffff;
text-align: center;
background: violet;
height:100px;
line-height: 100px;
} @media screen and (max-width : 600px){
.nav{
.flex(1,1,40%);
width:40%;
.order(1);
}
.main-content{
.flex(2,1,60%);
width:60%;
.order(2);
}
.sec{
.flex(1,1,100%);
.order(3);
}
}
<div class="wrapper">
<header class="main-header">header</header>
<div class="main-content">
<p>伸缩容器:一个设有“display:flex”或“display:inline-flex”的元素
伸缩项目:伸缩容器的子元素
主轴、主轴方向:用户代理沿着一个伸缩容器的主轴配置伸缩项目,主轴是主轴方向的延伸。
主轴起点、主轴终点:伸缩项目的配置从容器的主轴起点边开始,往主轴终点边结束。
主轴长度、主轴长度属性:伸缩项目的在主轴方向的宽度或高度就是项目的主轴长度,伸缩项目的主轴长度属性是width或height属性,由哪一个对着主轴方向决定。
侧轴、侧轴方向:与主轴垂直的轴称作侧轴,是侧轴方向的延伸。
侧轴起点、侧轴终点:填满项目的伸缩行的配置从容器的侧轴起点边开始,往侧轴终点边结束。
侧轴长度、侧轴长度属性:伸缩项目的在侧轴方向的宽度或高度就是项目的侧轴长度,伸缩项目的侧轴长度属性是「width」或「height」属性,由哪一个对着侧轴方向决定。</p>
</div>
<nav class="nav">
<ul>
<li><a href="javascript:void 0;">home</a></li>
<li><a href="javascript:void 0;">help</a></li>
<li><a href="javascript:void 0;">find</a></li>
<li><a href="javascript:void 0;">search</a></li>
</ul>
</nav>
<section class="sec">
section
</section>
<footer class="main-footer">footer</footer>
</div>

CSS3的flex布局的更多相关文章

  1. CSS3:flex布局应用

    想把先前的整理的东西贴出来,怎奈总是有额外事情发生,额,教训电脑要离水杯远点~~ 推荐一本书,<编写可维护的Javascript>这是Nicbolas C.Zakas写的,他的<Ja ...

  2. [Css] css3的flex布局

    flex思维导图 {"name":"flex","children":[{"name":"传统布局方式&quo ...

  3. 【CSS3基础-Flex布局】

    关于Flex 背景 在flex布局出现以前,常用的水平和垂直居中对齐方式有很多.flex布局的出现基本规范了这一过程. 通过justify-content和align-items两个属性即解决了水平居 ...

  4. 第103天:CSS3中Flex布局(伸缩布局)详解

    一.Flex布局 Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为Flex布局. .box{ display: flex; } 行 ...

  5. CSS3之flex布局

    若要使用flex布局,需在父元素上声明" display : flex ",这样它所有的直系子元素就成为flex元素 1.居中 1)垂直居中:align-items : cente ...

  6. 使用css3的Flex布局实现列表展示

    实现效果图如下: 通过css3样式实现(部分代码): .box { display: flex; flex-wrap:wrap; justify-content:space-between; alig ...

  7. CSS3弹性伸缩布局(二)——flex布局

    上一篇博客<CSS3弹性伸缩布局(一)——box布局>介绍了旧版本的box布局,而这篇博客将主要介绍最新版本的flex布局的基础知识. 新版本简介 新版本的Flexbox模型是2012年9 ...

  8. CSS3弹性盒模型,Flex布局教程

    布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现. CSS3中引入flex的弹性盒模型 ...

  9. 使用Sass优雅并高效的实现CSS中的垂直水平居中(附带Flex布局,CSS3+SASS完美版)

    实现css水平垂直居中的方法有很多,在这里我简单的说下四种比较常用的方法: 1.使用CSS3中的Flex布局 对于flex,我们要了解的是它是一个display的属性,而且必须要给他的父元素设置fle ...

随机推荐

  1. java反射技术详解

    反射: 其实就是动态的从内存加载一个指定的类,并获取该类中的所有的内容. 反射的好处:大大的增强了程序的扩展性. 反射的基本步骤: 1. 获得Class对象,就是获取到指定的名称的字节码文件对象. 2 ...

  2. 2016NOIP总结

    从暑假开始学OI到现在,也已经过了4个月.说实话真是快啊...感觉没学什么东西就要去比赛了.怎么说呢,感觉自己真的是个菜鸡啊为什么就要去比赛呢.当初来到这里,是凭着兴趣来的,第一天能打那么多道题(19 ...

  3. 应用程序无法正常启动0xc0150002(windows server 2003)

    windows server 2003运行一个程序时出现 "应用程序无法正常启动0xc0150002"的错误提示; 解决方案: 下载地址:http://www.microsoft. ...

  4. JQuery的父、子、兄弟节点查找方法

    jQuery.parent(expr)           //找父元素 jQuery.parents(expr)          //找到所有祖先元素,不限于父元素 jQuery.children ...

  5. 最后一周psp

    团队项目PSP 一:表格     C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(mins) 讨论 讨论用户界面 10:20 11:45 25 40 80 分析 ...

  6. 浅谈Js闭包现象

    一.1.我们探究这个问题的时候如果按照正常的思维顺序,需要知道闭包是什么它是什么意思,但是这样做会让我们很困惑,了解这个问题我们需要知道它的来源,就是我们为什么要使用闭包,先不管它是什么意思!     ...

  7. Autocad 2012 win7(64位)启动时一直卡在acmgd.dll处的解决方案

    安装Autocad 2012后,激活成功后,无法正常启动,一直卡在加载acmgd.dll 通过Procmon监控后发现加载C:\Windows\fonts\AdobeFnt11.lst处出错, 通过命 ...

  8. [转]Android通过NDK调用JNI,使用opencv做本地c++代码开发配置方法

    原文地址:http://blog.csdn.net/watkinsong/article/details/9849973 有一种方式不需要自己配置所有的Sun JDK, Android SDK以及ND ...

  9. ASP.NET Core 优雅的在开发环境保存机密(User Secrets)

    前言 在应用程序开发的过程中,有的时候需要在代码中保存一些机密的信息,比如加密密钥,字符串,或者是用户名密码等.通常的做法是保存到一个配置文件中,在以前我们会把他保存到web.config中,但是在A ...

  10. [Xamarin] 使用Webview 來做APP (转帖)

    有時候,企業要求的沒有這麼多,他原本可能官方網站就已經有支援Mobile Web Design 他只需要原封不動的開發一個APP 也或是,他只是要型錄型,或是問卷調查的型的APP,這時候透過類似像if ...