zoukankan      html  css  js  c++  java
  • css清除浮动

    第一种方法:结尾处加空div标签 clear:both 

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .outer{
                border: 1px solid black;
                 300px;
            }
            .inner{
                 50px;
                height: 50px;
                background-color: #ff4400;
                margin-right: 20px;
                float: left;
            }
            .footer{
                background-color: #005FC3;
                 200px;
                height: 100px;
            }
            .clearfix{
                clear: both;
           height: 0;
           line-height: 0;
           font-size: 0;
    }
    </style> </head> <body> <div class="outer"> <div class="inner"></div> <div class="inner"></div> <div class="inner"></div> <div class="clearfix"></div> </div> <div class="footer"></div> </body> </html>

    优点:这种方法兼容性好

    缺点:但是有多余的标签

    第二种方法:使用 :after 为元素

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .outer{
                border: 1px solid black;
                 300px;
            }
            .inner{
                 50px;
                height: 50px;
                background-color: #ff4400;
                margin-right: 20px;
                float: left;
            }
            .footer{
                background-color: #005FC3;
                 200px;
                height: 100px;
            }
            .clearfix:after{  
                content: '.';
                display: block;
                clear: both;
           height:0;
           visibility:hidden; }
    .clearfix{ /*兼容 IE*/ zoom: 1; } </style> </head> <body> <div class="outer clearfix"> <div class="inner"></div> <div class="inner"></div> <div class="inner"></div> </div> <div class="footer"></div> </body> </html>

    原理:IE8以上和非IE浏览器才支持:after,zoom(IE转有属性)可解决ie6,ie7浮动问题 

    优点:浏览器支持好、不容易出现怪问题(目前:大型网站都有使用,如:腾迅,网易,新浪等等) 

    缺点:IE8以上和非IE浏览器才支持:after

    建议:推荐使用,建议定义公共类,以减少CSS代码。 

    第三种:父级div定义 overflow:hidden 或是auto

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .outer{
                border: 1px solid black;
                 300px;
                overflow: hidden;
                zoom: 1;/*兼容 IE*/
            }
            .inner{
                 50px;
                height: 50px;
                background-color: #ff4400;
                margin-right: 20px;
                float: left;
            }
            .footer{
                background-color: #005FC3;
                 200px;
                height: 100px;
            }
        </style>
    </head>
    <body>
        <div class="outer">
            <div class="inner"></div>
            <div class="inner"></div>
            <div class="inner"></div>
        </div>
        <div class="footer"></div>
    </body>
    </html>

    原理:必须定义width或zoom:1,同时不能定义height,使用overflow:hidden时,浏览器会自动检查浮动区域的高度 

    优点:简单、代码少、浏览器支持好 

    缺点:不能和position配合使用,因为超出的尺寸的会被隐藏。 

    建议:只推荐没有使用position或对overflow:hidden理解比较深的朋友使用。 

    第四种:给父元素定高

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .outer{
                border: 1px solid black;
                 300px;
                height: 50px;
            }
            .inner{
                 50px;
                height: 50px;
                background-color: #ff4400;
                margin-right: 20px;
                float: left;
            }
            .footer{
                background-color: #005FC3;
                 200px;
                height: 100px;
            }
        </style>
    </head>
    <body>
        <div class="outer">
            <div class="inner"></div>
            <div class="inner"></div>
            <div class="inner"></div>
        </div>
        <div class="footer"></div>
    </body>
    </html>

    原理:父级div手动定义height,就解决了父级div无法自动获取到高度的问题。 

    优点:简单、代码少、容易掌握 

    缺点:只适合高度固定的布局,要给出精确的高度,如果高度和父级div不一样时,会产生问题 

    建议:不推荐使用,只建议高度固定的布局时使用

    参考:https://segmentfault.com/a/1190000003937063

  • 相关阅读:
    系统生命周期
    系统分析师教程——目录
    企业信息系统——SCM
    企业信息系统——CRM
    .NET 解决方案 核心库整理
    .NET 人工智能相关资料整理
    Task
    正则表达式摘录
    记一次IOS对 JS的支持问题
    JavaScript回顾一下js的基础知识,以及学习一下在项目中了解到的新知识
  • 原文地址:https://www.cnblogs.com/myzy/p/6184194.html
Copyright © 2011-2022 走看看