本文首发于个人博客 http://www.lijundong.com/image-and-line-height/

今天在做一个静态页面时,图片底部出现一条 3px 高度的白边,既不是 margin 也不是 padding,找了好久没能解决,后来才发现与 line-height 相关,问题解决后查缺补漏,这里作下笔记。
解决问题之前需要理清楚几个概念,基线、line-height、vertical-align、inline 元素。

基线(baseline)

基线(Baseline) 是字体排印学中的概念,指的是多数字母排列的基准线,大多字母都沿着红色基线排列,举个例子辅助理解

图中 xHh 字母的下边缘红线就是基线的所在,那么有没有一个特定的条件来定义基线呢?这里有个概念可供参考

字母x的下边缘(线)就是基线的所在。

这里又引出了 x-height 的概念,此处不表。

line-height

关于 line-height 如何定义的讨论,有说法是两条基线之间的距离,看到这个结论我首先想到第一行的行高如何处理,后来去找了资料,发现两条基线之间的距离即是 line-height 这样的结论并不准确。
关于 line-height 的定义,MDN 阐述如下:

On block level elements, the line-height property specifies the minimum height of line boxes within the element.
On non-replaced inline elements, line-height specifies the height that is used to calculate line box height.

block 元素中, line-height 的值等于元素中高度最低的行框(line box) 的高度值。
在 non-replaced inline 元素中,line-height 的值等于行框(line box) 的高度值。

**注:**
**replaced element 对比 non-replaced element**- replaced element: 例如 img、video、canvas 此类渲染出的内容引用外部的元素
- non-replaced element: 渲染自身的 content

例如

<a href="lijundong.com">Leeon Blog</a>

此类,渲染出的内容来自自身。

inline(内联) 元素

HTML5 中的常见 inline 元素如下:

  • inline:span、strong、em
  • inline-block:input、button、textarea、select、img

vertical-align

vertical-align 作用于 inline 元素 以及 table-cell 元素,还有

::first-letter

::first-line

,更多内容可以参见 MDN

属性分类:

适用于 inline 元素的属性:

/* keyword values */
vertical-align: baseline;  /*基于基线对齐*/
vertical-align: sub;
vertical-align: super;
vertical-align: text-top;
vertical-align: text-bottom;
vertical-align: middle;
vertical-align: top;
vertical-align: bottom;/* <length> values */
vertical-align: 10em;
vertical-align: 4px;/* <percentage> values */
vertical-align: 20%;/* Global values */
vertical-align: inherit;
vertical-align: initial;
vertical-align: unset;

适用于 table-cell 的属性:

vertical-align: top;
vertical-align: bottom;
vertical-align: middle;

回到问题

问题代码示例如下,

<style >* {padding: 0;margin:  0;}body {background-color: #ccc;}img {width: 100px;}div ,p {font-size: 100px;background-color: #fff;}
</style>
<body><div ><img src="headpic.png"></div>
</body>

代码效果图如下,红框圈出部分为出现的白条

通过对代码稍作修改可以轻松看出问题所在,实图如下

有了上面的铺垫,现在回头看遇到的问题,就很简单了,究其原委,首先 img 元素默认对齐方式为

vertical-align: baseline;

,这就导致了,baseline 以下的部分被空了出来,显示了背景的白色。

问题找到了,对症下药可得出下面的解决方案:

  • 根本上消除 img 的对齐方式 —— 块状化:
img { display: block;
}
  • 更改 img 对齐方式,以下三种均可
img {vertical-align: top;vertical-align: middle;vertical-align: bottom;
}
  • 更改行高,行高是两条 baseline 之间的距离,因此可以暴力的让行高消失
{ line-height: 0;/* font-size: 0; 当 line-height 使用数值、百分比或者 rem 定义时也可用这种方式,因为 line-height 参照的是 font-size 的值*/
}

总结

遇到问题多多求证,即便是很常见的问题也会挖出大学问,在求证的过程中也不能尽用拿来主义,多参考 w3c 和 MDN 的文档。
写的过程中,修修补补了好几回,关于 vertical-align 的内容讲的很仓促,后面会补上,如果文中表达有误,烦请指出,感谢。


参考:

  • CSS深入理解之vertical-align
  • CSS Baseline: The Good, The Bad And The Ugly
  • 基线 wiki
  • How CSS line-height is measured?
  • Understanding the CSS box model
  • Inline elements and line-height

inline「一」:从 image 底部白边初识 line-height相关推荐

  1. 「Linux」- 运行任天堂红白机游戏(“小霸王”) @20210308

    问题描述 # 02/16/2021 今天,闲来无事(其实也有事,就是累了,想休息一下),想再玩一玩这些小游戏,重温经典,所以就有了这篇文章,来记录这一过程.当我们不会去买一个红白机,虽然有卖的.我们想 ...

  2. Ps 初学者教程「42」如何利用渐变工具实现平滑过渡?

    欢迎观看 Photoshop 教程,小编带大家了解如何利用渐变工具实现平滑过渡. 在 Photoshop 中合成图片时,要获得无缝渐变的混合效果,最好的方法就是图层蒙版和渐变工具搭配使用.在本教程中, ...

  3. Ps 初学者教程「62」如何在图片中创建新背景?

    欢迎观看 Photoshop 教程,小编带大家了解如何使用 ps 将照片主题置于全新环境中. 不需要旅行预算来为您的照片寻找新的背景,第一步是隐藏朴素的灰色墙.选中模特图层,来到工具面板选择「快速选择 ...

  4. Ps 初学者教程「48」如何使用仿制图章工具移除对象?

    欢迎观看 Photoshop 教程,小编带大家了解如何使用仿制图章工具从图片中精确移除对象. 如果你需要尽可能准确地复制图片中的细节,以便从图片中移除一些内容时,可以使用 Photoshop 中的仿制 ...

  5. Ps 初学者教程「41」如何使用图层蒙版合成图像?

    欢迎观看 Photoshop 教程,小编带大家了解如何使用图层蒙版合成图像. 在 Photoshop 中合成图像最有效的方法之一就是,使用图层蒙版来确定图层中的哪些内容要在合成图像中显示.在本教程中, ...

  6. 「杂谈」白身,初识,不惑,有识,你处于深度学习哪一重境界了

    https://www.toutiao.com/a6701683817700147715/ 今天我们来谈谈深度学习工程师那些境界的事儿.有三斗胆将学习深度学习的同志分为5大境界,分别是白身,初识,不惑 ...

  7. 谷歌相册也不能无限白嫖了,「地主家」也烧不起免费网盘

    木易 发自 凹非寺  量子位 报道 | 公众号 QbitAI 连Google都撑不住了. Google相册宣布:从2021年6月1日开始,将停止提供免费的无限制存储空间. 这意思,是不让「白嫖」了? ...

  8. 「递归」第4集 | 退役黑客带你走进白帽子的江湖

    我们为什么叫「递归」 "递归" (recursion) 是一种在程序设计语言中被广泛使用的算法.它有两大特点,一是调用自己,二是化繁为简.我们当中那些优秀的技术人又何尝不是如此?他 ...

  9. 在校大学生如果连「校招」都不知道,那大学就白读了

    今天看到一条留言: 结合我的经历,简单聊聊我的看法吧. 信息差 如果经常逛知乎的同学,可能会发现三歪经常会在知乎水回答.三歪会经常看到类似的问题:「大四马上毕业了,如何找到一份好的Java工作」 很多 ...

最新文章

  1. 改变自己,让自己变得更好
  2. 为什么delete表数据,磁盘空间却还是被占用
  3. LeetCode (12.整数转罗马数字)JAVA StringBuffer
  4. Kafka文件存储机制及offset存取
  5. hdu 5586(最大连续子序列和)
  6. CriminalIntent项目的开发
  7. windows 的mysql5.7安装
  8. MySql 存储过程实例(附完整注释)
  9. vc++ List Control控件获得所有选中行的序号
  10. jboss5.1安全性配置_使用Java EE安全性和JBoss AS 7.x保护JSF应用程序的安全
  11. MongoDB更新文档(非常详细,不要错过~)
  12. 【响应式布局】理解设备像素、设备独立像素和css像素
  13. 8.1.1使用BlockingQueue和ArrayBlockingQueue
  14. 零基础学习软件测试必看的python之基础语法
  15. DM 数据库体系结构
  16. markdown中编辑复杂表格
  17. python获取登录后的cookie_python爬虫使用cookie登录详解
  18. 疯狂天才乔治·霍兹:17岁黑掉苹果,22岁搞垮索尼,还是特斯拉、谷歌最可怕的对手!
  19. 简单绕过chrome(谷歌游览器) 查看已保存的密码
  20. Linux网络管理以及端口聚合详解

热门文章

  1. centos安装盘ntfs_在CentOS下挂载NTFS格式U盘的方法
  2. java报错找不到对象,使用Spring源码报错java:找不到类 InstrumentationSavingAgent的问题...
  3. ubuntu16.04+cuda9.0_cudnn7.5+tensorflow-gpu==1.12.0
  4. JS-this的使用
  5. ]remove-duplicates-from-sorted-list-ii (删除)
  6. [bzoj3532][Sdoi2014]Lis
  7. XP退役对整个互联网安全的问题
  8. mongodb查询内嵌文档
  9. opencv python tutorials_OpenCV-Python Tutorials 笔记(二)
  10. g2 折线图点与点之间直线_科学网—ggplot2实现散点折线图 - 肖斌的博文