zoukankan      html  css  js  c++  java
  • [Web 前端] 解决因inline-block元素导致的空白间距和元素下沉

     cp from : https://www.jianshu.com/p/617e78a27c88

    ** 前言: ** CSS 中的 display:inline-block 是笔者最为喜欢的元素之一,可以将原本占据一行的块级元素,转变为可以并列显示的行内块级元素。

    display:inline-block 常被用来代替float进行页面布局,不过正所谓金无足赤、人无完人,当使用 inline-block 后会出现“4px”的空白间距。
    关于如何消除这 “ 4px ” 的空白间距,网上已经有了不少方法,其中个人觉得用font-size:0 解决空白间距是最为方便简单的了。
    下面做个简单的Demo
    .html
    <body>
        <div class="a"></div>
        <div class="b"></div>
    </body>
    
    .css
    .a{
         100px;
        height: 100px;
        background: #1c8cff;
        display: inline-block;
    
    }
    .b{
         100px;
        height: 100px;
        background: #676767;
        display: inline-block;
    }
    

      

    接着为两个盒子的父元素添加 font-size:0

    body{
        font-size: 0;
    }


    元素下沉

    
    

    另外,当给inline-block元素中添加东西时,发现其元素也会随之下沉。

    .html
    <body>
        <div class="a"><span>test</span></div>
        <div class="b"></div>
        <div class="c"></div>
    </body>
    .css
    body{
        font-size: 0;
    }
    .a{
         100px;
        height: 100px;
        background: #1c8cff;
        display: inline-block;
        font-size: 21px;
    }
    .b{
         100px;
        height: 100px;
        background: #676767;
        display: inline-block;
    }
    .c{
         100px;
        height: 100px;
        background: #00a74a;
        display: inline-block;
    }
    

      

    而解决方法可以用vertical-align属性。

    .css
    .a{
         100px;
        height: 100px;
        background: #1c8cff;
        display: inline-block;
        vertical-align: top;
        font-size: 21px;
    }
    

      

  • 相关阅读:
    sql 查询多列 小于某值
    C#读取EXCEL 并输出到文本框
    字典
    MVC 接收文件
    C# DataTable 转 json
    MVC 返回json数据
    C# 获得指定路径扩展名 , 去除扩展名
    C# 分割URL地址
    sql语句参数化问题
    VC++学习之网络编程中的套接字
  • 原文地址:https://www.cnblogs.com/0616--ataozhijia/p/9415362.html
Copyright © 2011-2022 走看看