CSS3弹性盒模型 display:box

  刚开始做网页时就有一个困惑,为什么display:block只能垂直排列,如果要水平排列就要使用float:left等方式。这种方法最难受的当然是当子元素的数量改变时,需要去修改子元素的宽度使重新适应。bootstrap为了兼容性在实现栅格布局时,就不得不生成大量如下代码:

.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {
  float: left;
}
.col-xs-12 {
  width: 100%;
}
.col-xs-11 {
  width: 91.66666667%;
}
.col-xs-10 {
  width: 83.33333333%;
}

  好在有less,使代码量大减,比如:

.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) {
  [email protected]{class}[email protected]{index} {
    width: percentage((@index / @grid-columns));
  }
}
.loop-grid-columns(@index, @class, @type) when (@index >= 0) {
    .calc-grid-column(@index, @class, @type);
    // next iteration
    .loop-grid-columns((@index - 1), @class, @type);
}

  而CSS3给出了直接的解决方案,就是display: box。当然这个CSS3属性如大多数没得到浏览器的直接支持,需要在box前面加上浏览器的前缀。

  给出最初的代码。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        html, body {
            height: 100%;
            margin: 0;
        }
        body {
            background: black;
        }
        article {
            display: -webkit-box;
            height: 100%;
        }
        article div {
        }
        article div:nth-child(1) {
            background: red;
        }
        article div:nth-child(2) {
            background: green;
        }
        article div:nth-child(3) {
            background: blue;
        }
    </style>
</head>
<body>
    <article>
        <div>123</div>
        <div>abc</div>
        <div>tarol</div>
    </article>
</body>
</html>

  打开chrome,得到的效果如图:

  首先比较与传统display:block的不同:

  1. 子元素按照水平排列
  2. 子元素的宽度没填充
  3. 子元素的高度填充了

  好像就是由display:block的垂直排列转换到了display:box的水平排列。但display:box的功能更加强大,上面三个行为都是可以单独控制的。

  1. 由box-orient控制,默认inline-axis(===horizontal),可设置为block-axis(===vertical)

    article {
        display: -webkit-box;
        height: 100%;
       /* 注意这里加前缀的使property,前面是value*/
        -webkit-box-orient: vertical;
    }

    效果图:

  2. 由box-flex控制,这个作用于子元素,让子元素具备‘弹性’,具备‘弹性’的子元素可以伸缩到充满父元素
    比如我们把第一个子元素的‘弹性’设置为1

    article div:nth-child(1) {
        background: red;
        -webkit-box-flex: 1;
    }

    效果图:

    把所有子元素的‘弹性’设置为1,由于大家的弹性一样,所以宽度一样

    article div {
        -webkit-box-flex: 1;
    }

    效果图:

    把第一个子元素的‘弹性’设置为2,其他的维持1不变,由于第一个子元素的‘弹性’是其他子元素的两倍,所以占位也是其他子元素的两倍。就是把老爸的财产分成4份,老大独占2份,老二和老三各得1份。

    article div:nth-child(1) {
        background: red;
        -webkit-box-flex: 2;
    }

    效果图:

    乍看一下是对的,但凡事就怕认真fanjian二字。打开F12,看了下width,老二和老三一个是344px,另一个是359px。(老二:就因为我叫老二么)。
    原因出在哪里?出在元素的innerHTML,一个是abc三个字符,一个是tarol五个字符。就像一个弹簧,弹性是一样的,但一个比另一个多两节,拉伸的长度能一样么?处理方式是将所有赋予box-flex属性的子元素全部加上:width:0

    article div {
        -webkit-box-flex: 1;
        width: 0;
    }

    现在对比下,发现是一样的了,或者有1px的差别(老爸:咱一个钢镚就别剁成两瓣了)

  3. 由box-align控制,默认是stretch,即填充。可选值是start/end/center/baseline。
    先把之前的flex全部取消掉,然后将可选值赋给父元素,效果图分别如下
    start/baseline:

    end:

    center: 

    总结一下,当box-orient为horizontal时,box-align定义子元素的垂直位置,当box-orient为vertical时,box-align定义子元素的水平位置
  4. 说到box-align,就不得不说box-pack,它的作用和box-align是相辅相成的。取值范围也相似:start(default)/end/center/justify。
    将box-align设置为start,对box-pack分别取值,得到的效果如下:
    end: 

    center: 

    justify:

    同样总结下,当box-orient为horizontal时,box-pack定义子元素的水平位置,当box-orient为vertical时,box-pack定义子元素的垂直位置。从表现来看,box-pack更接近text-align的意义,而box-align更接近vertical-align。
  5. box-direction,显示子元素的顺序,类似css中的direction,可选值normal(default)/reserve
    删除其他的css property,回归到原始状态,给父元素添加box-direction: reserve,效果图如下:
  6. box-ordinal-group,box-direction可以逆向显示,box-ordinal-group则可以定义显示的具体次序,作用于子元素。

    article > div:nth-child(1) {
        background: red;
        -webkit-box-ordinal-group: 2;
    }
    article > div:nth-child(2) {
        background: green;
        -webkit-box-ordinal-group: 3;
    }
    article > div:nth-child(3) {
        background: blue;
        -webkit-box-ordinal-group: 1;
    }

    效果图:

    同时设置box-direction,则同样进行逆向显示

  7. box-flex-group,作用于子元素,为子元素设定‘弹性’功能的分组。默认为1,也就是都在第一组。
    为第一个元素的box-flex-group赋值为2

    article > div {
        -webkit-box-flex: 1;
        width: 0;
    }
    article > div:nth-child(1) {
        background: red;
        -webkit-box-flex-group: 2;
    }
    article > div:nth-child(2) {
        background: green;
    }
    article > div:nth-child(3) {
        background: blue;
    }

    效果让人震惊,老大不见了:

    因为对box-flex-group的定义是这样的,父元素先分配给组序号大的子元素需要的空间,然后剩余空间全部交给组序号小的子元素去‘弹’。
    就是说,老爸的财产老大要多少给多少,剩下的其他人去分,那老大要多少?他说了:我什么都不要(width:0),所以没有了。(老大:我没说啊)
    修改下第一个子元素的width

    article > div:nth-child(1) {
        background: red;
        -webkit-box-flex-group: 2;
        width: 200px;
    }

    效果如下:

    老大又说了:妈蛋有这种好事,那我全要!

    article > div:nth-child(1) {
        background: red;
        -webkit-box-flex-group: 2;
        width: 100%;
    }

    然后:

    然后他就被揍了。

  每次写完一篇,总有一种好像漏写了什么的感觉。年过完了,也一个多月没更新了,这篇作为开始吧。

时间: 2024-09-30 06:54:51

CSS3弹性盒模型 display:box的相关文章

CSS3弹性盒模型flex box快速入门 2016.03.16

@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css); @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css); @import url(htt

CSS3盒模型display:box;box-flex:3;

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width"> <title>盒模型display:box;</title> </head> <body> <article class=&q

CSS3弹性盒模型flexbox完整版教程

文章目录 基础知识 属性介绍 display: flex | inline-flex; (适用于父类容器元素上) 请注意: flex-direction (适用于父类容器的元素上) flex-wrap (适用于父类容器上) flex-flow (适用于父类容器上) justify-content (适用于父类容器上) align-items (适用于父类容器上) align-content (适用于父类容器上) order (适用于弹性盒模型容器子元素) flex-grow (适用于弹性盒模型容

CSS3弹性盒模型flexbox布局基础版

原文链接:http://caibaojian.com/using-flexbox.html 最近看了社区上的一些关于flexbox的很多文章,感觉都没有我这篇文章实在,最重要的兼容性问题好多人都没有提出解决方案.另外本人2014年5月还废寝忘食的翻译了国外的<CSS3弹性盒模型flexbox完整教程>和<CSS3弹性盒模型flexbox布局实例>,这么好的文章没有人来发现,实在是遗憾. 文章写作背景 查询Can I use上的使用情况,发现最新的浏览器基本支持这个属性,IE10开始

css3基础教程:CSS3弹性盒模型

今天给大家分享一篇关于CSS3基础教程 文章,主要是讲CSS3弹性盒模型.弹性布局的主要思想是让容器有能力来改变项目的宽度和高度,以填满可用空间(主要是为了容纳所有类型的显示设备和屏幕尺寸)的能力. 注意:Flexbox布局是最合适的一个应用程序的组件,以及小规模的布局,而网格布局是用于较大规模的布局. 盒模型的兼容性不佳,在使用时,需要加上浏览器的私有前缀. 父元素display:box或者display:inline-box; display: -webkit-box;display: -m

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

布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现. CSS3中引入flex的弹性盒模型,这是一个可以让你告别浮动.完美实现垂直水平居中的新特性. 尽管目前css3在PC端上的兼容性还不是那么完美,但是在移动端已基本实现兼容. 网络上有很多关于flex布局很好的教程.总结的也很完美,我就直接收藏了,以备查询 详解css3弹性盒模型(Flexbox) 移动端开发小记 – Flexbox

CSS3盒模型display:box详解

display:box;box-flex是css3新添加的盒子模型属性,它的出现可以解决我们通过N多结构.css实现的布局方式.经典的一个布局应用就是布局的垂直等高.水平均分.按比例划分.目前box-flex属性还没有得到firefox.Opera.chrome浏览器的完全支持,但可以使用它们的私有属性定义firefox(-moz-).opera(-o-).chrome/safari(-webkit-).一.box-flex属性box-flex主要让子容器针对父容器的宽度按一定规则进行划分htm

[转]CSS3盒模型display:box详解

时间:2014-02-25来源:网络作者:未知编辑:RGB display:box;box-flex是css3新添加的盒子模型属性,它的出现可以解决我们通过N多结构.css实现的布局方式.经典的一个布局应用就是布局的垂直等高.水平均分.按比例划分. 目前box-flex属性还没有得到firefox.Opera.chrome浏览器的完全支持,但可以使用它们的私有属性定义firefox(-moz-).opera(-o-).chrome/safari(-webkit-). 一.box-flex属性 b

CSS3弹性盒模型之box-orient &amp; box-direction

Css3引入了新的盒模型——弹性盒模型,其实上一篇文章已经讲到了一个box-flex,今天来讲讲另外的两个弹性盒模型属性box-orient 和 box-direction. 1.box-origent: 水平或垂直分布. box-origent有两个值:horizional(水平)和vertical(垂直),意思就是元素的排列方式! css代码如下: body {display: -webkit-box; -webkit-box-orient: horizional; } 水平排列方式如下: