行内元素、行内块元素空白问题

1.元素之间的空白问题

产生的原因:

        行内元素、行内块元素,彼此之间的换行会被浏览器解析为一个空白字符。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        * {
            padding: 0;
            margin: 0;
            text-align: center;
        }
        span {
            background-color: gainsboro;
        }
    </style>
</head>
<body>
    <div>
        <span>item1</span>
        <span>item2</span>
        <span>item3</span>
        <span>item4</span>
        <span>item5</span>
        <span>item6</span>
    </div>
</body>
</html>

解决方案:

        方案一: 去掉换行和空格(不推荐)。

<body>
    <div>
        <span>item1</span><span>item2</span><span>item3</span><span>item4</span><span>item5</span><span>item6</span>
    </div>
</body>

        方案二: 给父元素设置 font-size:0 ,再给需要显示文字的元素,单独设置字体大小(推 荐)。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        * {
            padding: 0;
            margin: 0;
            text-align: center;
        }
        .father {
            font-size: 0;
        }
        span {
            background-color: gainsboro;
            font-size: 20px;
        }
    </style>
</head>
<body>
    <div class="father">
        <span>item1</span>
        <span>item2</span>
        <span>item3</span>
        <span>item4</span>
        <span>item5</span>
        <span>item6</span>
    </div>
</body>
</html>

 

2.行内块的幽灵空白问题

产生原因:

        行内块元素与文本的基线对齐,而文本的基线与文本最底端之间是有一定距离的。

  比如图标下方会有空白,代码如下

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        * {
            padding: 0;
            margin: 0;
            text-align: center;
        }
        .father {
            background-color: gray;
        }
        img {
            width: 100px;
        }
    </style>
</head>
<body>
    <div class="father">
        <span>test</span>
        <img src="../assets/img/add.png" alt="" srcset="">
    </div>
</body>
</html>

解决方案:

        方案一: 给行行内块设置 vertical ,值不为 baseline 即可,设置为 middel 、 bottom 、 top 均可。

       

img {
            width: 100px;
            vertical-align: bottom;
        }

        方案二: 若父元素中只有一张图片,设置图片为 display:block 。

        方案三: 给父元素设置 font-size: 0 。如果该行内块内部还有文本,则需单独设置 font-size 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值