美文网首页
  • 标签之间空隙bug
  • 标签之间空隙bug
  • 作者: lovelydong | 来源:发表于2018-12-20 09:54 被阅读0次
      <li class="blist_item">
                              <img src="img/book_list.png" alt="" />
                          </li>
      
      QQ截图20181220095051.png

      解决:

      一、将图片转换为块级对象

      即,设置img为“display:block;”。在本例中添加一组CSS代码:

      .blist_item img {display:block;}
      

      二、设置图片的垂直对齐方式

      即设置图片的vertical-align属性为“top,text-top,bottom,text-bottom”也可以解决。如本例中增加一组CSS代码:

      .blist_item img {vertical-align:top;
      

      三、设置父对象的文字大小为0px

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

      四、改变父对象的属性

      如果父对象的宽、高固定,图片大小随父对象而定,那么可以设置“overflow:hidden;”来解决。如本例中可以向.blist_item中添加以下代码:

      .blist_item{width:200px;height:300px;overflow:hidden;}
      

      五、设置图片的浮动属性

      即在本例中增加一行CSS代码:

      .blist_item img {float:left;}
      

      如果要实现图文混排,这种方法是很好的选择。

      六、取消图片标签和其父对象的最后一个结束标签之间的空格。

      这个方法要强调下,在实际开发中该方法可能会出乱子,因为在写代码的时候为了让代码更体现语义和层次清晰,难免要通过IDE提供代码缩进显示,这必然会让标签和其他标签换行显示,比如说DW的“套用源格式”命令。

      原因分析

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

      至于这里的HTML属性align=”center”(对于图片浏览器会处理成align=”middle”),就相当于vertical-align:middle; 所以道理也是一样的,只要vertical-align不取baseline,这个空隙就消失了。

      原文链接

      相关文章

        网友评论

            本文标题:

          • 标签之间空隙bug

            本文链接:https://www.haomeiwen.com/subject/zkbekqtx.html