html中两个块之间有空隙,css标签之间引发空隙问题解决办法

首先看这段空隙对应的源代码如下

代码看起来没有任何问题,那么问题真的来了:

空隙去哪里了啊?

问题原因:

图片文字等inline元素默认是和父级元素的baseline对齐的,而baseline又和父级底边有一定距离(这个距离和 font-size,font-family 相关,不一定是 5px),所以设置 vertical-align:top/bottom/text-top/text-bottom 都可以避免这种情况出现。而且不光li,其他的block元素中包含img也会有这个现象。

解决方案:

将图片display: block

设置img为“display:block;”。在本例中添加一组CSS代码:“img {display:block;}”。比较常用的做法。

设置图片的对齐方式

即设置图片的vertical-align属性为“top,text-top,bottom,text-bottom”也可以解决

设置图片的父级对象文字大小为0px

“font-size:0;”可以解决问题。但这也引发了新的问题,在父对象中的文字都无法显示。就算文字部分被子对象括起来,设置子对象文字大小依然可以显示,但在CSS效验的时候会提示文字过小的错误。

设置图片的浮动

即在本例中增加一行CSS代码:“#sub img {float:left;}”。如果要实现图文混排,这种方法是很好的选择。

各种做法自行考量,我偏向于设置浮动或块显示,有些人偏向于使用vertical-align进行解决。

a_33209

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值