• CSS清除浮动的方法


      CSS清除浮动的方法有哪些呢?经常性地会使用到float,很多邪门的事儿都有可能是浮动在作怪,清除浮动是必须要做的,而且随时性地对父级元素清除浮动的做法也被认为是书写CSS的良好习惯之一。
    下面看今天的教程,此为未清除浮动源代码,运行代码无法查看到父级元素浅黄色背景。

    <style type=”text/css”>
    <!–
        *{margin:0;padding:0;}
        body{font:36px bold; color:#F00; text-align:center;}
        #layout{background:#FF9;}
        #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>

    一、使用空标签清除浮动

      我用了很久的一种方法,空标签可以是div标签,也可以是P标签。我习惯用<div>,够简短,也有很多人用<hr>,只是需要另外为其清除边框,但理论上可以是任何标签。这种方式是在需要清除浮动的父级元素内部的所有浮动元素后添加这样一个标签清楚浮动,并为其定义CSS代码:clear:both。此方法的弊端在于增加了无意义的结构元素。
    <style type=”text/css”>
    <!–
        *{margin:0;padding:0;}
        body{font:36px bold; color:#F00; text-align:center;}
        #layout{background:#FF9;}
        #left{float:left;20%;height:200px;background:#DDD;line-height:200px;}
        #right{float:right;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>
        <div class=”clr”></div>
    </div>

    二、使用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>

    三、使用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”>
        

  • 相关阅读:
    省市区distpicker,从数据库里查出来回显,动态绑定
    ajax请求里面的success和error里面的layer.msg,status: "parsererror",刷新父界面,碰到的一些问题
    排序算法时间和空间算法度
    适配器模式
    守护线程
    工厂模式之简单工厂模式、工厂模式、抽象工厂
    ArrayList源码分析和缩减版手写ArrayList(jdk1.8和1.9)
    HashMap排序题
    二进制中1的个数
    anaconda指定镜像源,解决conda下载速度慢失败问题
  • 原文地址:https://www.cnblogs.com/diyxiaoshitou/p/3968350.html
Copyright © 2020-2023  润新知