解决inline-block中间缝隙

7 篇文章 0 订阅

解决inline-block中间缝隙

本质:inline-block中间缝隙的本质是html中存在的空白字符(inline-block标签之间的回车符)
举例:

li {
  display: inline-block;
  background-color: red;
}
<ul>
  <li><a href="#">登录</a></li>
  <li><a href="#">快速注册</a></li>
  <li><a href="#">关于</a></li>
  <li><a href="#">帮助</a></li>
  <li><a href="#">APP下载</a></li>
</ul>
一、去除空白符
  1. 删除inline-block元素之间的换行符
<ul>
  <li><a href="#">登录</a></li><li><a href="#">快速注册</a></li><li><a href="#">关于</a></li><li><a href="#">帮助</a></li><li><a href="#">APP下载</a></li>
</ul>

原理:因为换行符会导致空白符从而导致inline-block元素之间的间隙。
缺点:降低可读性。

2.将闭合标签换行

<ul>
  <li><a href="#">登录</a>
  </li><li><a href="#">快速注册</a>
  </li><li><a href="#">关于</a>
  </li><li><a href="#">帮助</a>
  </li><li><a href="#">APP下载</a>
  </li>
</ul>

原理:去除空白符,增加可读性。

二、将父节点的font-size设置为0
ul{
  font-size:0;
}

li{
  font-size:1.2rem;
  display: inline-block;
  background-color: red;
}

原理:空白符所占的大小为0。
缺点:

  1. 子元素需要单独设置font-size
  2. 会出现下边距等问题
三、标签不闭合
 <ul>
  <li><a href="#">登录</a>
  <li><a href="#">快速注册</a>
  <li><a href="#">关于</a>
  <li><a href="#">帮助</a>
  <li><a href="#">APP下载</a>
</ul>

原理:html会自动补不闭合的标签

四、设置负边距
li+li {
  margin-left: -3px;
}

原理:设置负边距,清除空白。
缺点:无法兼容所有浏览器,每个浏览器的边距可能不一样。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值