zoukankan      html  css  js  c++  java
  • 为什么a标签中使用img后的高度多了几个像素?

    首先贴两张图对问题进行描述:在这个页面上有一个包含img标签的a标签,通过审查元素,可以看到img标签的宽和高是150*232,。

    下面再看一下a标签的宽高,150*236,高度多了4个像素。

    这是什么问题呢?去网上搜了好多,决定记录下来这个坑。

    出现这种情况的原因是:a元素下有一个匿名文本,这个文本外有一个匿名行级盒子,它有的默认vertical-align是baseline的,而且往往因为上文line-height的影响,使它有个line-height,从而使其有了高度,因为baseline对齐的原因,这个匿名盒子就会下沉,往下撑开一些距离,所以把a撑高了。

    解决办法一:消除掉匿名盒子的高度,也就是给a设置line-height:0或font-size:0;
    解决办法二:给两者vertical-align:top,让其top对齐,而不是baseline对齐
    解决办法三:给img以display:block,让它和匿名行级盒子不在一个布局上下文中,也就不存在行级盒的对齐问题


  • 相关阅读:
    html 注释和特殊字符
    html 锚点链接
    html 链接标签
    spring 利用工厂模式解耦
    html 路径
    html 图像标签
    html div和span标签
    html 文本格式化标签
    P5358 [SDOI2019]快速查询
    luoguP2679 子串
  • 原文地址:https://www.cnblogs.com/yxxlin/p/7125512.html
Copyright © 2011-2022 走看看