CSS实现图片垂直居中方法

html

html 复制代码
    <div class="footer border-top-row">
      <div class="footer-row">
        <span class="footer-row-col01"
          >制单人:{{ printData[pageIndex - 1].rkMaster.makerName
          }}<img :src="getPersonSignImgSrc(printData[pageIndex - 1].rkMaster.makerName!)" alt="" style="height: 28px"
        /></span>
        <span class="footer-row-col02"
          >审核人:{{ printData[pageIndex - 1].rkMaster.makerName
          }}<img :src="getPersonSignImgSrc(printData[pageIndex - 1].rkMaster.makerName!)" alt="" style="height: 28px"
        /></span>
      </div>
      <div class="footer-row pageNum">
        <span>第 {{ printData[pageIndex - 1].pageIndex }} 页 / 共 {{ printData[pageIndex - 1].pageCount }} 页</span>
      </div>
    </div>

可以通过以下CSS设置实现图片垂直居中:

css

复制

下载

复制代码
.footer-row-col01,
.footer-row-col02 {
  display: inline-flex;  /* 启用flex布局 */
  align-items: center;   /* 垂直居中 */
  vertical-align: middle; /* 双重保障 */
}

.footer-row-col01 img,
.footer-row-col02 img {
  vertical-align: middle; /* 图片自身垂直对齐 */
  margin-left: 4px;       /* 可选:添加与文字的间距 */
}

代码解释:

  1. 父容器设置(关键)

    • display: inline-flex:将span转换为行内flex容器,保持行内特性同时可以使用flex布局

    • align-items: center:通过flex布局实现垂直居中

    • vertical-align: middle:作为备用方案,防止flex布局未生效时的保障

  2. 图片设置

    • vertical-align: middle:修正行内元素的默认基线对齐问题

    • margin-left:可选,用于增加图片与前面文字的间距

补充说明:

  • 如果遇到间距问题,可以尝试在父容器添加 gap: 4px 属性

  • 确保父级元素有足够的高度,垂直居中效果才能明显

  • 如果使用Sass/Less等预处理器,建议将这些样式封装到对应的class中

最终效果:图片将与同行的文字在垂直方向上完美对齐,无论字号如何变化都能保持居中状态。

css

html 复制代码
<style scoped lang="scss">

.footer {
  // 子绝
  position: absolute;
  bottom: 0;
  &-row {
    display: flex;
    height: 30px;
    line-height: 30px;
    &-col01 {
      width: 480px;
    }
    &-col02 {
      width: 238px;
    }
    &-col01,
    &-col02 {
      display: flex; /* 启用flex布局 */
      align-items: center; /* 垂直居中 */
      vertical-align: middle; /* 双重保障 */
      gap: 10px; /* 横向间距 */
    }
  }

</style>

效果

相关推荐
Cutecat_4 分钟前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
dsyyyyy11016 分钟前
JavaScript变量
开发语言·javascript·ecmascript
qq_4221525725 分钟前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen37 分钟前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
brucelee1861 小时前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
ct9782 小时前
React 状态管理方案深度对比
开发语言·前端·react
胡志辉的博客2 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop
代码不加糖2 小时前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js
懂懂tty2 小时前
Vue2与Vue3之间API差异
前端·javascript·vue.js
AI焦点3 小时前
跨越协议鸿沟:Tool Use状态机从Anthropic到OpenAI兼容体系的适配要点
前端·人工智能