zoukankan      html  css  js  c++  java
  • 清除浮动的深入理解

    一、问题场景

    html文件:

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="utf-8">
        <title>blog</title>
        <link href="" rel="stylesheet">
        <link rel="stylesheet" href="css/reset.css">
        <link rel="stylesheet" href="css/main.css">
    </head>
    
    <body>
        <!--页头开始-->
    
        <head>
            <nav>
                <div class="logo"><a href="#">XX</a></div>
                <ul>
                    <li><a href="#" class="active">首页</a></li>
                    <li><a href="#">链接2</a></li>
                    <li><a href="#">链接3</a></li>
                    <li><a href="#">链接4</a></li>
                </ul>
            </nav>
            <div id="banner">
                <div class="inner">
                    <h1>XX的网站</h1>
                    <p class="sub-heading">Lorem ipsum dolor sit amet, consectetur adipisicing elit. </p>
                    <button>了解我</button>
                    <div class="more">
                        更多
                    </div>
                </div>
            </div>
        </head>
        <!--页头结束-->
        <!--内容开始-->
        <div class="content">
            <section class="green-section">
                <div class="wrapper">
                    <div>
                        <h2>一个标题</h2>
                        <div class="hr"></div>
                        <p class="sub-heading">Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
                    </div>
                    <div class="icon-group">
                        <span class="icon">item1</span>
                        <span class="icon">item2</span>
                        <span class="icon">item3</span>
                    </div>
                </div>
            </section>
            <section class="gray-section">
                <div class="article-preview">
                    <div class="img-section">
                        <img src="img/pic01.jpg" alt="">
                    </div>
                    <div class="text-section">
                        <h2>又一个标题</h2>
                        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
                    </div>
                </div>
            </section>
            <section class="purple-section"></section>
        </div>
        <!--内容结束-->
        <!--页尾结束-->
        <footer></footer>
        <!--页头结束-->
    </body>
    
    </html>

    css文件

    @charset "UTF-8";
    
    
    nav {
        background-color: #ccc;
        height: 50px;
    }
    
    #banner {
        background-color: #777;
        height: 700px;
    }
    
    nav ul {
        list-style: none;
        margin: 0;
        float: right;
    }
    
    nav ul li,
    nav .logo {
        display: inline-block;
        line-height: 50px;
        margin-right: 20px;
    }
    
    nav ul li a {
        line-height: 50px;
        text-decoration: none;
        display: inline-block;
        height: inherit;
        color: #fff;
    }
    
    nav .logo {
        float: left;
        margin-left: 10px;
        line-height: 50px;
    }
    
    #banner .inner {
        max-width: 300px;
        text-align: center;
        margin: 0 auto;
        position: relative;
        top: 160px;
    }
    
    #banner .inner h1 {
        margin: 0;
    }
    
    button {
        border: none;
        background: #333;
        color: #eee;
        padding: 10px;
    }
    
    #banner button {
        padding: 14px 40px;
    }
    
    #banner .inner .more {
        margin-top: 200px;
    }
    
    .sub-heading {
        line-height: 30px;
        margin: 30px;
    }
    
    .logo {
        font-size: 20px;
        font-weight: bold;
        letter-spacing: 1px;
    }
    
    .logo a {
        color: #fff;
    }
    .active{
        border-bottom: 4px solid #fff;
    }
    h1{
        padding: 12px;
        border-top: 2px solid #fff;
        border-bottom: 2px solid #fff;
    }
    
    h2{
        margin: 0px;
        font-size: 30px;
    }
    .hr{
        height: 2px;
        width: 100%;
        margin:20px auto;
    }
    
    .sub-heading {
        font-size: 18px;
    }
    
    #main-btn{
        padding: 14px 28px;
        font-size: 20px;
        letter-spacing: 4px;
        border-radius: 6px;
        background: #18a;
    }
    .green-section{
        text-align: center;
        background: #089DB0;
        color: #fff;
        padding: 100px 0;
    }
    .green-section .hr{
        background: #078494;
        width: 60%;
    }
    .green-section .icon-group .icon{
        display: inline-block;
        width: 80px;
        height: 80px;
        border: 1px solid #0D6F7C;
        transform: rotate(45deg);
        margin:20px;
    }
    
    .icon-group{
        margin-top: 60px;
    }
    .wrapper{
        max-width: 1080px;
        margin: 0 auto;
    
    }
    .gray-section{
        background:#252F34 ;
        color: #fff;
    }
    .gray-section .img-section{
        width: 45%;
    }
    .img-section img{
        width: 100%;
    }
    .gray-section .text-section{
        width: 55%;
    }
    .article-preview >div{
        float: left;
    }
    .article-preview:after{
        content: '';
        display: block;
        clear: both;
    }

    删除了.article-preview:after效果,可以看到.article-preview的高度为0

    加上.article-preview:after的效果,可以看到.article-preview的高度为409

    二、问题分析

    如果所有子元素都浮动,则父级盒子中的所有内容均脱离标准文档流,此时的父级盒子里面相当于没有内容,因为都飘离文档流了,也就是说父级盒子的高度为零,则呈现网页本身(body)的白色,设置了clear:both清除浮动之后,相当于此时的子元素拥有浮动属性可以并排显示,但并没有脱离标准文档流,即填充了整个父盒子。
    除了clear:both清除浮动解决浮动塌陷这种情况外,还可以给父盒子设置一个合理的高度,也可以解决浮动塌陷,不会出现如上背景变为白色的情况。

    三、实际应用总结

    由于这种场景应用非常多,一般我们会在css中定义一个类的样式

    如下

    .clearfix:after{
        content: '';
        display: block;
        clear: both;
    }

    需要使用时只需要加上类即可

    <div class="card-group clearfix"></div>
  • 相关阅读:
    moss文档浏览次数统计
    C#中方法参数的四种类型
    [记录] JavaScript 中的深浅拷贝(克隆)
    [记录] JavaScript 中的事件分类
    [记录] JavaScript 中的数组操作
    [记录] JavaScript 中的事件(Event对象、事件源对象、事件流、事件绑定)
    [记录] JavaScript 中的try..catch 详细的错误信息
    [题目] JavaScript 练习题目(一) [020]
    [记录] JavaScript 中的this和call()、apply()方法
    [记录] JavaScript 中的对象操作和包装类
  • 原文地址:https://www.cnblogs.com/knyel/p/7813137.html
Copyright © 2011-2022 走看看