zoukankan      html  css  js  c++  java
  • 清除浮动的3种方法

    使用div+css布局的好处不用多说,经常性地会使用到float,那么清除浮动就是必须要做的,而且随时性地对父级元素清除浮动的做法也被认为是书写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 
    11 <div id="layout"> 
    12     <div id="left">Left</div> 
    13     <div id="right">Right</div> 
    14 </div>

    1、使用空标签清除浮动。我用了很久的一种方法,空标签可以是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 
    12 <div id="layout"> 
    13     <div id="left">Left</div> 
    14     <div id="right">Right</div> 
    15     <p class="clr"> 
    16 </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;20%;height:200px;background:#DDD;line-height:200px;} 
        #right{float:right;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;20%;height:200px;background:#DDD;line-height:200px;} 
        #right{float:right;30%;height:80px;background:#DDD;line-height:80px;} 
    --> 
    </style> 

    <div id="layout"> 
        <div id="left">Left</div> 
        <div id="right">Right</div> 
    </div>
    此三种方法皆有一定弊端,使用时应择优选择,比较之下第二种方法更为可取。以上方法,并非原创,皆来源于网络,在此小作整理,原作者保留所有权利。

  • 相关阅读:
    REST接口设计规范总结
    Linux 下建立 Git 与 GitHub 的连接
    Linux centos修改防火墙为iptables
    一些开源软件的国内镜像源
    centOS7下安装GUI图形界面
    mysql使用锁的分析
    php后台添加默认图片
    php执行时间
    递归获取所有分类下面子分类的id
    php laravel左连接leftJoin多条where语句
  • 原文地址:https://www.cnblogs.com/rhinemetal/p/2568548.html
Copyright © 2011-2022 走看看