CSS vertical-align

这里的小空白就是为了和基线对齐

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>垂直对齐方式</title>
  <style>
    div {
      border: 1px solid #000;
    }

    img {
      /* vertical-align: middle; */

      /* 顶对齐:最高内容的顶部 */
      /* vertical-align: top; */

      /* 底对齐:最高内容的底部 */
      /* vertical-align: bottom; */

      /* 因为浏览器把行内块、行内标签当做文字处理,默认按基线对齐 */
      /* 效果:图片img的底下有空白,转块级不按基线对齐,空白就消失了 */
      /* display: block; */
    }
  </style>
</head>
<body>
  <div>
    <img src="./images/1.webp" alt="">
    我是谁?我在哪?
  </div>
</body>
</html>

在 HTML 中,图片默认是按照基线对齐的方式来布局的,这是因为浏览器将图片视为一个内联元素,就像文字一样,所以会遵循内联元素的对齐规则。以下是具体原因:

  • 内联元素的特性:在 CSS 中,内联元素(如文字、图片等)通常会在一行内显示,并且它们的垂直对齐方式默认是基于基线的。基线是一条虚构的线,大多数字母都位于基线上或基线以上,字母的底部与基线对齐。
  • 兼容性和传统:这种基线对齐的方式是从早期的网页设计和浏览器渲染机制中继承下来的,为了保持与旧版本的 HTML 和 CSS 规范的兼容性,以及与大多数网页设计实践的一致性,浏览器一直沿用了这种默认的对齐方式。
  • 文本排版的一致性:将图片与文字的基线对齐有助于在文本段落中保持整体的排版一致性。当图片和文字在同一行时,它们的底部会大致对齐,使得文本流看起来更加整齐和自然。

vertical-align 是一个用于控制行内元素(如文本、图片、图标)在垂直方向上对齐方式的 CSS 属性。它主要用于调整元素在行高内的位置,或在行内格式化上下文中的对齐方式。

核心作用

  1. 行内元素对齐:控制元素(如文本、图片、图标)在行内的垂直位置。
  2. 表格单元格对齐:在表格中控制内容的垂直对齐方式。
  3. 与行高配合:常用于解决行内元素(如图片、图标)与文本基线不一致的问题。

注意事项

  1. 仅作用于行内元素vertical-align 只对 display: inlineinline-blocktable-cell 等行内元素有效,对块级元素无效
  2. 常见对齐问题 :图片底部留白通常是因为 vertical-align: baseline 默认值导致的,可以通过设置 vertical-align: bottomdisplay: block 解决。
相关推荐
程序员爱钓鱼3 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder3 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
JIngJaneIL4 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
敲敲了个代码4 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_4 小时前
列表渲染(v-for)
前端·javascript·vue.js
JustHappy4 小时前
「chrome extensions🛠️」我写了一个超级简单的浏览器插件Vue开发模板
前端·javascript·github
Loo国昌4 小时前
Vue 3 前端工程化:架构、核心原理与生产实践
前端·vue.js·架构
sg_knight5 小时前
拥抱未来:ECMAScript Modules (ESM) 深度解析
开发语言·前端·javascript·vue·ecmascript·web·esm
LYFlied5 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展