css中的 vertical-align与line-height作用详解

一、vertical-align 详解

  1. 作用对象:行内元素(inline/inline-block)或表格单元格内容
  2. 核心功能:控制元素在行框内的垂直对齐方式
  3. 常用取值
    • baseline(默认):基线与父元素基线对齐
    • top:元素顶部与行框顶部对齐
    • middle:元素中线与父元素基线+1/2 x-height对齐
    • bottom:元素底部与行框底部对齐
    • 数值值:2px(上移)、-10%(下移)

示例(图标与文本对齐):

css 复制代码
.icon {
  vertical-align: middle;
  width: 20px;
}
.text {
  vertical-align: middle;
}

二、line-height 详解

  1. 作用对象:块级容器
  2. 核心功能:定义行框的最小高度
  3. 特性
    l i n e − h e i g h t = 字体大小 + 上半间距 + 下半间距 line-height = 字体大小 + 上半间距 + 下半间距 line−height=字体大小+上半间距+下半间距
    • 无单位值(推荐):1.5(相对于当前字体大小)
    • 固定值:24px
    • 百分比:150%

文本垂直居中实现:

css 复制代码
.box {
  height: 50px;
  line-height: 50px; /* 单行文本垂直居中 */
}

三、相互关系

  1. 基线对齐依赖:vertical-align的基线对齐基于line-height计算的基线位置

  2. 行框高度计算

    html 复制代码
    <div style="line-height: 30px;">
      <span style="font-size: 40px; vertical-align: top">A</span>
      <span style="vertical-align: bottom">B</span>
    </div>

    实际行框高度=最高元素的顶部到最低元素的底部距离

  3. 数值计算示例

    当字体大小为16px,line-height为1.5时:
    16 p x × 1.5 = 24 p x 16px × 1.5 = 24px 16px×1.5=24px

    实际行框高度可能因vertical-align调整而变化

四、常见问题解决方案

  1. 图片底部间隙

    css 复制代码
    img {
      vertical-align: bottom; /* 或 top/middle */
      /* 或 */
      display: block;
    }
  2. 多行文本居中

    css 复制代码
    .container {
      display: flex;
      align-items: center;
      line-height: normal; /* 重置单行设置 */
    }
  3. 精确对齐控制

    css 复制代码
    .icon-text {
      display: inline-flex;
      align-items: center;
      vertical-align: middle;
    }

五、调试技巧

  1. 使用开发者工具显示基线:

    css 复制代码
    * {
      background: linear-gradient(#fff 94%, red 94% 96%, #fff 96%);
    }
  2. 可视化line-height区域:

    css 复制代码
    p::before {
      content: '';
      display: inline-block;
      height: calc(var(--line-height) - 1em);
      background: rgba(0,255,0,0.2);
    }
相关推荐
Filotimo_4 小时前
2.CSS3.(2).html
前端·css
yinuo5 小时前
uniapp微信小程序华为鸿蒙定时器熄屏停止
前端
gnip6 小时前
vite中自动根据约定目录生成路由配置
前端·javascript
前端橙一陈7 小时前
LocalStorage Token vs HttpOnly Cookie 认证方案
前端·spring boot
~无忧花开~7 小时前
JavaScript学习笔记(十五):ES6模板字符串使用指南
开发语言·前端·javascript·vue.js·学习·es6·js
泰迪智能科技018 小时前
图书推荐丨Web数据可视化(ECharts 5)(微课版)
前端·信息可视化·echarts
CodeCraft Studio8 小时前
借助Aspose.Email,使用 Python 读取 Outlook MSG 文件
前端·python·outlook·aspose·email·msg·python读取msg文件
家里有只小肥猫9 小时前
react 初体验2
前端·react.js·前端框架
慧慧吖@10 小时前
前端发送请求时,参数的传递格式
前端
L李什么李10 小时前
HTML——使用表格制作简历
前端·javascript·html