CSS清除浮动常用方法小结(2)

作者:heiniu 来源:阿里妈妈UED 时间:2009-07-07 11:59:00 

三种清除浮动方法如下:

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

ps:<br clear=”all”/>也可以实现效果,但不清楚使用哪个比较好。呵呵

<style type=”text/css”>
<!–
*{margin:0;padding:0;}
body{font:36px bold; color:#F00; text-align:center;}
#layout{background:#FF9;}
#left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;}
#right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;}
.clr{clear:both;}
–>
</style>
<div id=”layout”>
<div id=”left”>Left</div>
<div id=”right”>Right</div>
<p class=”clr”> </p>
</div>

2、使用overflow属性。

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

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

3、使用after伪对象清除浮动。

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

<style type=”text/css”>
<!–
*{margin:0;padding:0;}
body{font:36px bold; color:#F00; text-align:center;}
#layout{background:#FF9;}
#layout:after{display:block;clear:both;content:”";visibility:hidden;height:0;}
#left{float:left;width:20%;height:200px;background:#DDD;line-height:200px;}
#right{float:right;width:30%;height:80px;background:#DDD;line-height:80px;}
–>
</style>
<div id=”layout”>
<div id=”left”>Left</div>
<div id=”right”>Right</div>
</div>

清除浮动后如图所示:

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

标签:css,布局,float,清除浮动
0
投稿

猜你喜欢

  • 在弹出窗口用POST提交数据

    2010-02-24 09:39:00
  • asp是的日期转换为星座的函数

    2011-02-26 11:11:00
  • asp如何实现无组件上传二进制文件?

    2010-06-03 10:09:00
  • 无法通过Google网站管理工具验证的部分情况解决办法

    2009-07-28 12:56:00
  • 让你的空间支持域名绑定子目录的解决办法

    2010-09-15 10:03:00
  • 浏览器 cookie 限制

    2008-05-23 13:09:00
  • Firefox 下 innerHTML 的一个 BUG

    2008-08-05 18:19:00
  • Oracle 随机数

    2009-06-04 10:01:00
  • Study jQuery in a Simplified Way

    2010-01-30 12:55:00
  • 使用ASP遍历并列表显示目录文件

    2009-11-08 18:32:00
  • 怎样设置密码保护问题

    2009-02-16 13:12:00
  • asp网上考试设计思路是怎样的?

    2010-07-14 21:09:00
  • Yahoo发布一款FireFox网站开发插件

    2007-09-23 16:11:00
  • 用ASP实现远程批量文件改名

    2007-09-12 12:23:00
  • FSO无效的过程调用或参数问题

    2010-03-25 21:49:00
  • 启动iis出现发生意外0x8ffe2740的解决方法

    2011-03-31 11:19:00
  • ASP + Serv-u 实现FTP的代码

    2009-02-02 09:52:00
  • asp函数遍历文件夹代码

    2010-06-21 10:38:00
  • 如何在一个广告旗帜里轮番显示时间长度不一的不同广告?

    2010-06-26 12:35:00
  • 《悟透JavaScript》感谢语

    2008-11-12 12:59:00
  • asp之家 网络编程 m.aspxhome.com