您当前的位置:首页 > 网页设计 > Web开发 > 正文

DivCSS经验:三种实用CSS清除浮动的方法

【字体大小: 2009-12-03 18:10 来源: 作者: 

  应用DivCSS网页布局,经常性地会使用到float,很多邪门的事儿都有可能是浮动在作怪,关于清除浮动,在52CSS.com上有过很多介绍。清除浮动是必须要做的,而且随时性地对父级元素清除浮动的做法也被认为是书写CSS的良好习惯之一。

  CSS清除浮动的另一种别致的方法

  CSS经验分享:清除浮动及闭合浮动元素方法的总结

  下面看今天的教程,此为未清除浮动源代码,运行代码无法查看到父级元素浅黄色背景。  

  1. <style type=”text/css”>   
  2. <!–   
  3.     *{margin:0;padding:0;}   
  4.     body{font:36px bold; color:#F00; text-align:center;}   
  5.     #layout{background:#FF9;}   
  6.     #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;}   
  7.     #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;}   
  8. >   
  9. </style>   
  10. <div id=”layout”>   
  11.     <div id=”left”>Left</div>   
  12.     <div id=”right”>Right</div>   
  13. </div> 

  未清除浮动前如图所示:

  

 

  一、使用空标签清除浮动

  我用了很久的一种方法,空标签可以是div标签,也可以是P标签。我习惯用<p>,够简短,也有很多人用<hr>,只是需要另外为其清除边框,但理论上可以是任何标签。这种方式是在需要清除浮动的父级元素内部的所有浮动元素后添加这样一个标签清楚浮动,并为其定义CSS代码:clear:both。此方法的弊端在于增加了无意义的结构元素。

  1. <style type=”text/css”>   
  2. <!–   
  3.     *{margin:0;padding:0;}   
  4.     body{font:36px bold; color:#F00; text-align:center;}   
  5.     #layout{background:#FF9;}   
  6.     #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;}   
  7.     #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;}   
  8.     .clr{clear:both;}   
  9. >   
  10. </style>   
  11. <div id=”layout”>   
  12.     <div id=”left”>Left</div>   
  13.     <div id=”right”>Right</div>   
  14.     <p class=”clr”>   
  15. </div> 

  二、使用overflow属性

  此方法有效地解决了通过空标签元素清除浮动而不得不增加无意代码的弊端。使用该方法是只需在需要清除浮动的元素中定义CSS属性:overflow:auto,即可!”zoom:1″用于兼容IE6。  

  1. <style type=”text/css”>   
  2. <!–   
  3.     *{margin:0;padding:0;}   
  4.     body{font:36px bold; color:#F00; text-align:center;}   
  5.     #layout{background:#FF9;overflow:auto;zoom:1;}   
  6.     #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;}   
  7.     #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;}   
  8. >   
  9. </style>   
  10. <div id=”layout”>   
  11.     <div id=”left”>Left</div>   
  12.     <div id=”right”>Right</div>   
  13. </div> 

  三、使用after伪对象清楚浮动

  该方法只适用于非IE浏览器。具体写法可参照以下示例。使用中需注意以下几点。一、该方法中必须为需要清除浮动元素的伪对象中设置height:0,否则该元素会比实际高出若干像素;二、content属性是必须的,但其值可以为空,蓝色理想讨论该方法的时候content属性的值设为”.”,但我发现为空亦是可以的。  

  1. <style type=”text/css”>   
  2. <!–   
  3.     *{margin:0;padding:0;}   
  4.     body{font:36px bold; color:#F00; text-align:center;}   
  5.     #layout{background:#FF9;}   
  6.     #layout:after{display:block;clear:both;content:”";visibility:hidden;height:0;}   
  7.     #left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;}   
  8.     #right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;}   
  9. >   
  10. </style>   
  11. <div id=”layout”>   
  12.     <div id=”left”>Left</div>   
  13.     <div id=”right”>Right</div>   
  14. </div> 

  清楚浮动后如图所示:

  

 

  此三种方法各有利弊,使用时应择优选择,比较之下第二种方法更为可取。

    顶一下
    (4)
    80%
    踩一下
    (1)
    20%
    【责任编辑:绝口不提】 标签:
    最新评论 查看所有评论
    发表评论 查看所有评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    评价:
    表情:
    用户名:密码:验证码: