box-flex:也就是让子容器针对父容器的宽高属性依照一定的规则来划分

Eg:

html代码:

<div class="wrap">

<div class="box1">01</div>

<div class="box2">02</div>

<div class="box3">03</div>

</div>

CSS样式:

<style type="text/css">

body,div { background:#fff; margin:0; padding:0;}

.wrap { width:600px; height:200px; color:#fff; margin:20px 0 0 20px; text-align:center;

display:-moz-box; display:-webkit-box; display:box;

-moz-box-orient:block-axis; -webkit-box-orient:block-axis; box-orient:block-axis;

-moz-box-direction:reverse; -webkit-box-direction:reverse; box-direction:reverse;

}

.box1 {background:red;

-moz-box-flex:3; -webkit-box-flex:3; box-flex:3;

-moz-box-ordinal-group:1; -webkit-box-ordinal-group:1; box-ordinal-group:1;

}

.box2 {background:green;

-moz-box-flex:1; -webkit-box-flex:1; box-flex:1;

-moz-box-ordinal-group:3; -webkit-box-ordinal-group:3; box-ordinal-group:3;

}

.box3 {background:blue;

-moz-box-flex:2; -webkit-box-flex:2; box-flex:2;

-moz-box-ordinal-group:2; -webkit-box-ordinal-group:2; box-ordinal-group:2;

}

</style>

预览效果:

解析:

先看父级的元素中中设置的属性

1、box-orient:block-axis;      使得子元素依照块级类型竖向显示。

2、box-direction:reverse;      使得子元素显示顺序与默认相颠倒。

再看子元素中的属性(这个以红色区域且标有01文字的模块为例来做具体介绍)

1、box-flex:3;  子元素按照无级元素设置了占有比例。

从全局来看,一共将低级元素划分成了6份。而红色区域是占了3/6的。即上图中显示所总体高度的1/2。

2、box-ordinal-group:1;   即给每个子元素定义了一个组,则依照组的大小来呈现,先小后大;  依照组中定义的大小,本应该是红色居上、蓝色居中、绿色最下显示,而在父级的元素中中定义了一个子元素的反向呈现方式(box-direction:reverse),即与默认相反。

讲到这里。我想大家都豁然开朗了吧!呵呵,当然也存在疑问。假设想让当中某一模块设置为固定数字。那么其它模块又会按如何的比例来呈现呢?我们能够再看一下以下这个样例(由例1稍做修改)。

静态代码不变、样式由之前的改为:

<style type="text/css">

body,div { background:#fff; margin:0; padding:0;}

.wrap { width:600px; height:200px; color:#fff; margin:20px 0 0 20px; text-align:center;

display:-moz-box; display:-webkit-box; display:box;

-moz-box-orient:block-axis; -webkit-box-orient:block-axis; box-orient:block-axis;

-moz-box-direction:reverse; -webkit-box-direction:reverse; box-direction:reverse;

}

.box1 {background:red;

-moz-box-flex:3; -webkit-box-flex:3; box-flex:3;

-moz-box-ordinal-group:1; -webkit-box-ordinal-group:1; box-ordinal-group:1;

}

.box2 {background:green;

height:100px;

-moz-box-ordinal-group:3; -webkit-box-ordinal-group:3; box-ordinal-group:3;

}

.box3 {background:blue;

-moz-box-flex:2; -webkit-box-flex:2; box-flex:2;

-moz-box-ordinal-group:2; -webkit-box-ordinal-group:2; box-ordinal-group:2;

}

</style>

预览效果:

这个时候。绿色模块的高度是固定的,设置为100,占领了父元素的一半。

从预览图能够看出,无论哪个模块。一旦设置了固定的宽或者是高,则优先级会比較高。而其它模块呢,还是依照之前的那种思路。用对应比例来显示。要注意的是,这时候的总宽或者高就变了。应

css3中 弹性盒模型布局之box-flex的更多相关文章

  1. CSS3 中弹性盒模型--容器的属性

    1.display : flex | inline-flex注意,设为 Flex 布局以后,子元素的float.clear和vertical-align属性 将失效. 2.flex-direction ...

  2. CSS3弹性盒模型布局模块介绍

    来源:Robert’s talk原文:http://robertnyman.com/2010/12/02/css3-flexible-box-layout-module-aka-flex-box-in ...

  3. 87.CSS Flex 弹性盒模型布局教程(共用的css在48篇文章gird)

    CSS Flex 弹性盒模型布局教程 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. flex布局就是给任何一个容器添加 dis ...

  4. 彻底搞懂flex弹性盒模型布局

    为什么要用flex 基于css3简单方便,更优雅的实现,浏览器兼容性好,传统的css实现一个div居中布局要写一堆代码,而现在几行代码就搞定了,没有理由不用flex. 兼容性: Base Browse ...

  5. CSS-3 新弹性盒模型属性

    flex 语法:flex:none | [ flex-grow ] || [ flex-shrink ] || [ flex-basis ] 取值: none:none关键字的计算值为: 0 0 au ...

  6. css3之弹性盒模型初探(一)

    什么是弹性盒模型? 弹性盒模型是指在父级改变大小的时候内部的自己元素也会相应的改变大小,即子集会按照父级的大小按比例自适应大小. 弹性盒模型的提出可以解决一些响应式布局的需求   如何使用弹性盒模型? ...

  7. 详细介绍弹性盒模型(display:flex)

    弹性盒模型,即Flexbox,是css3中的新特性,其实弹性盒模型的原身是dispaly:box:这里,我们暂时不考虑旧的,我们只看新的. 为容器指定弹性盒子,只需在父元素(也就是容器)中设置:dis ...

  8. css3之弹性盒模型(Flex Box)

    CSS3 弹性盒子(Flex Box) 弹性盒子是 CSS3 的一种新的布局模式. CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时 ...

  9. CSS3弹性盒模型布局模块

    原文:http://robertnyman.com/2010/12/02/css3-flexible-box-layout-module-aka-flex-box-introduction-and-d ...

随机推荐

  1. Codeforces 766E

    题意:给一棵树(1e5),每个节点上有对应权值(0<=ai<=1e6)定义树上两个节点间的距离为路径中节点的异或,求所有节点对间的距离和(包括节点自身也作为节点对,距离为节点权值). 解题 ...

  2. mysql多表查询 查询排序

    有 ask 问题表  和 answer回答表  回答表中的ask_id和 ask表中的id对应 1.查询 /*查询回答了的 */select a.id,a.title,count(b.ask_id) ...

  3. shell script练习:利用日期进行文件的创建

    随日期变化:利用 date 进行文件的创建 想像一个状况,假设我的服务器内有数据库,数据库每天的数据都不太一样,因此当我备份时, 希望将每天的数据都备份成不同的档名,这样才能够让旧的数据也能够保存下来 ...

  4. scala函数用法

    直接上代码. package com.test.scala.test object Function { def main(args: Array[String]): Unit = { println ...

  5. Mysql中的索引()key 、primary key 、unique key 与index区别)

    CREATE TABLE pre_forum_post ( pid int(10) unsigned NOT NULL COMMENT '帖子id', fid mediumint(8) unsigne ...

  6. mysql索引初认识

    mysql> use mysql; Database changed mysql> show index from user; +-------+------------+-------- ...

  7. javascript之console篇

    javascript中的console使用得当,将会事半功倍,对bug,性能等的跟踪,优化是个不错的利器! 1.基本日志消息打印: console.debug(msg); console.info() ...

  8. Java_Web三大框架之Hibernate+jsp+HQL分页查询

    分页查询无处不在.使用Hibernate+jsp+HQL进行分页查询. 第一步:编写房屋实体类和House.hbm.xml映射. /* * 房屋实体类 */ public class House { ...

  9. 在Yosemite中创建个人站点

    Yosemite变动很大,随之而来的就是一堆坑,之前在旧版OS中有效的方法在新版OS上已经不起作用了,创建个人站点就是一例. Mac OS内置Apache,安装目录在/etc/apache2/,etc ...

  10. Python常用的标准库及第三方库

    标准库Python拥有一个强大的标准库.Python语言的核心只包含数字.字符串.列表.字典.文件等常见类型和函数,而由Python标准库提供了系统管理.网络通信.文本处理.数据库接口.图形系统.XM ...