掌握css3布局(带实例)(一)

368 查看

在传统的浮动、定位基础之上,CSS3提供了一系列新的布局方式,包括弹性盒模型、多列、媒体查询等,利用这些布局方式我们可以灵活地应对复杂网页布局,本文通过属性详解、实战案例的方式向您展示这些新兴布局方式的强大之处。

1.弹性盒模型

弹性盒布局模型(Flexible Box Layout)是 CSS3 规范中提出的一种新的布局方式。该布局模型的目的是提供一种更加高效的方式来对容器中的条目进行布局、对齐和分配空间。这种布局方式在条目尺寸未知或动态时也能工作。这种布局方式已经被主流浏览器所支持,可以在 Web 应用开发中使用。

理解这个图image

本人文笔有限,这里我推荐别人写得很好的教程。

附带例子:

2.多列属性

CSS3中新出现的多列布局(multi-column)是传统HTML网页中块状布局模式的有力扩充。这种新语法能够让WEB开发人员轻松的让文本呈现多列显示。我们知道,当一行文字太长时,读者读起来就比较费劲,有可能读错行或读串行;人们的视点从文本的一端移到另一端、然后换到下一行的行首,如果眼球移动浮动过大,他们的注意力就会减退,容易读不下去。所以,为了最大效率的使用大屏幕显示器,页面设计中需要限制文本的宽度,让文本按多列呈现,就像报纸上的新闻排版一样。

但是在CSS3的多列布局(columns)语法功能出现之前,人们如果想让文本呈多列显示,要么使用绝对定位,手动给文本分段落,或者使用JS脚本等,而新语法的出现,彻底改变了这样的局面。

多列(columns)的用法

列个数 和 列宽度

不管想让一段文本呈多少列显示,你需要的只是两个属性:column-countcolumn-width

column-count 属性设置列的具体个数,例如:

<div style="column-count:2;">
CSS里一直有一个让我们头疼的问题,就是创建布局很麻烦。
当然,有很多方式,有很多技术都可以创建各种布局,但我
们总觉得CSS里应该提供一些新属性,让我们能更好的管理布局。
幸运的是,CSS3里提供了一批新的创建列式布局的column属性,
有了这些属性,我们不需要再使用float,clear,margin等属性进行
调控,避免了很多麻烦。
</div>

这将会使文本里的内容显示成两列(首先你的浏览器要支持这种新语法,比如火狐浏览器、谷歌浏览器,IE10+等):

image

column-width属性控制列的宽度。如果你没有提供column-count属性值,那么,浏览器就是自主决定将文本分成合适的列数。

<div style="column-width:10em;">
CSS里一直有一个让我们头疼的问题,就是创建布局很麻烦。
当然,有很多方式,有很多技术都可以创建各种布局,但我
们总觉得CSS里应该提供一些新属性,让我们能更好的管理布
局。幸运的是,CSS3里提供了一批新的创建列式布局的column
属性,有了这些属性,我们不需要再使用float,clear,margin
等属性进行调控,避免了很多麻烦。</div>

就变成了这样:

image

多列布局columns语法简写

大多时候,WEB程序员只需要同时使用这两个属中的一个:column-countcolumn-width。或者两个同时使用,幸运的是,这两个属性的属性值是不同单位,不会搞混,所以就有了简写方式,columns,例如:

我们之前写的 column-width:12em 可以用下面的写法替换:

<div style="columns:12em">CSS里一直有一个让我们头疼的
问题,就是创建布局很麻烦。当然,有很多方式,有很多技术
都可以创建各种布局,但我们总觉得CSS里应该提供一些新属
性,让我们能更好的管理布局。幸运的是,CSS3里提供了一批
新的创建列式布局的column属性,有了这些属性,我们不需要
再使用float,clear,margin等属性进行调控,避免了很多麻烦。
</div>

而之前写的 column-count:4 可以用以下语法简写替换:

<div style="columns:4">CSS里一直有一个让我们头疼的
问题,就是创建布局很麻烦。当然,有很多方式,有很多
技术都可以创建各种布局,但我们总觉得CSS里应该提供
一些新属性,让我们能更好的管理布局。幸运的是,CSS3
里提供了一批新的创建列式布局的column属性,有了这些
属性,我们不需要再使用float,clear,margin等属性进行
调控,避免了很多麻烦。
</div>

而同时声明了 column-width:8emcolumn-count:12 的情况可以用以下简写替换:

<div style="columns:12 8em">CSS里一直有一个让我们头疼的问题,就是
创建布局很麻烦。当然,有很多方式,有很多技术都可以创建各种布局,但
我们总觉得CSS里应该提供一些新属性,让我们能更好的管理布局。幸运的
是,CSS3里提供了一批新的创建列式布局的column属性,有了这些属性,我
们不需要再使用float,clear,margin等属性进行调控,避免了很多麻烦。</div>

列高度的平衡

CSS3规范里描述的是,各列的高度是均衡的,浏览器会自动调整每列里填充多少文本、均分文本,来使各列的高度保持均衡一致。

然而,有时候,我们需要设定列的最大高度,这个时候,文本内容会从第一列开始填充,然后第二列,第三列,也许以后的列会填不满,也许会溢出。所以,当对多列布局设定了heightmax-height属性值后,列会伸长到指定高度——无论内容有多少,够不够或超不超。

列之间的缝隙间隔宽度

两列之间会有缝隙间隔。缺省情况下这个间隔宽度是1em,但如果你使用column-gap属性,就会修改这个缺省的宽度值:

<div style="column-width:20em; column-gap:2em;">
CSS里一直有一个让我们头疼的问题,就是创建布局很麻烦。当然,
有很多方式,有很多技术都可以创建各种布局,但我们总觉得CSS里
应该提供一些新属性,让我们能更好的管理布局。幸运的是,CSS3里
提供了一批新的创建列式布局的column属性,有了这些属性,我们不
需要再使用float,clear,margin等属性进行调控,避免了很多麻烦。</div>

image

列布局的浏览器完美兼容

对于一些不支持多列布局特征的浏览器,比如IE9/IE8,会把这些属性全部忽略,这样布局就呈现出传统的单块布局。

为了保证浏览器最大的兼容性,我们在使用多列布局属性时,最好添加浏览器引擎前缀,最基本的要加上三种:谷歌浏览器的-webkit-,火狐浏览器的-moz-,IE浏览器的-ms-,最后,别忘了不带前缀的写法。

总结

CSS3的多列布局(columns)是一种方便WEB开发者高效利用宽屏显示器的非常有用的功能特征。你会发现在很多地方都需要用到它们,特别是需要自动平衡列高度的地方。

这篇文章就介绍到这里,下篇文章讲解响应式布局中的核心内容媒体查询的基础用法和常见使用方式及实例。