免费模板素材网-网页模板素材-网站模板免费下载

您现在的位置: 首页-设计教程-css+div教程
分享到:

CSS闭合浮动元素解析

作者:佚名 来源:来自网络 浏览次数: 编辑:免费模板网

按照CSS规范,浮动元素(floats)会被移出文档流,不会影响到块状盒子的布局而只会影响内联盒子(通常是文本)的排列。因此当其高度超出包含容器时,一般父容器不会自动伸长以闭合浮动元素。但是有时我们却需要这种自动闭合行为,具体如何处理呢?

<a href=


有一种做法就是在父容器内再插入一个额外的标签,并令其清除浮动(clear)以撑大父容器。这种方法浏览器兼容性好,没有什么问题,缺点就是需要额外的(而且通常是无语义的)标签,所以我个人不大喜欢。后来又有了一种新的方式,使用 :after 伪类动态的嵌入一个用于清除浮动的元素,这种方法和上一种原理一样,不同的只是把这个额外的内容用 CSS 生成,但考虑到 IE 不支持 :after 不得不做了不少的 hack。这种方法兼容性一般,但经过各种 hack 也可以应付不同浏览器了,同时又可以保证 html 比较干净,所以用得还是比较多的。再后来又有人发现将父容器的 overflow 设为除 visible 之外的值就可以在标准兼容浏览器中闭合浮动元素,IE自然又是不支持的,所以这种方法和上一种方法一样都对 IE 做了不同处理(具体就是触发layout),不同的就是overflow 没有 :after 伪类那么麻烦了,缺点也有,overflow 可能会产生一些小冲突。在使用 overflow 之前还有过一种使用 float 的方法,就是让父容器也浮动,这利用到了浮动元素的一个特性——浮动元素会闭合浮动元素。这种方式在 IE/Win 和标准兼容浏览器中都有较好的效果,但缺点也很明显——父容器未必想浮动就浮动的了,毕竟浮动是一种比较特殊的行为,有时布局不允许其浮动也很正常。使用 float 虽然在 IE 和标准兼容浏览器中都能闭合浮动元素,但原理却是不同的,IE/Win 中 float 触发了 layout 因而闭合了浮动,而在标准兼容浏览器中,float 其实和上一种方法中的 overflow 原理一样,产生了一个“块级格式化范围”——这是CSS 规范中提到的一种现象,它往往具有某种独立性,特性之一就是会自动闭合内部的浮动元素。

按照规范,以下类型的元素会产生一个块级格式化范围:

    浮动元素,left 或者 right 皆可。
    绝对定位的元素。
    inline-block 元素,不过这个 gecko目前不支持。
    table-cell 类型元素,其实 table, table-head-group, table-row 什么的也都可以,还有inline-
    table(gecko不支持)也同样,因为他们都会间接产生一个匿名的 table-cell。
    overflow 取值非 visible 的元素。

所以,原来在标准兼容浏览器中我们也可以有这么多的方法闭合一个浮动元素,而且只需要 CSS,无需其他。顺带说一下以上除了overflow,其余都有一个附加效果就是自动收缩父容器宽度。

而对于 IE/Win,它有一套自己的体系,就是 layout,具有 layout 的元素会自动闭合浮动元素,再来看看触发 layout 的 CSS 属性,会发现和上面的块级格式化范围有很多类似之处:

    浮动元素
    绝对定位元素
    display:inline-block
    zoom
    width/height
    overflow/overflow-x/overflow-y [IE7 新增]
    max/min-width/height [IE7 新增]

上一条:常用CSS2基本定义形式 下一条:如何实现根据浏览器和分辨率的不同自动调用CSS样式表?

版权声明: CSS闭合浮动元素解析,其版权归原作者所有。
网站首页 | 关于我们 | 联系方式 | 版权声明 | 广告合作 | 建站业务 | 网站报错 | 友情链接 | 订阅rss | 网站地图

免费模板素材网提供免费网页模板素材,免费导航代码,div css静态网页模板等模板素材下载,致力于打造绿色强大的免费模板素材资源下载站点!
2009-2015 www.mianfeimoban.com版权所有