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>

效果

相关推荐
Python私教16 分钟前
使用FastAPI和React以及MongoDB构建全栈Web应用05 FastAPI快速入门
前端·react.js·fastapi
浪裡遊19 分钟前
Typescript中的对象类型
开发语言·前端·javascript·vue.js·typescript·ecmascript
杨-羊羊羊26 分钟前
什么是深拷贝什么是浅拷贝,两者区别
开发语言·前端·javascript
发呆的薇薇°31 分钟前
在vue里,使用dayjs格式化时间并实现日期时间的实时更新
前端·javascript·vue.js
m0_6278275235 分钟前
vue3中 input 中放大镜在后面
javascript·vue.js·elementui
七冬与小糖1 小时前
【本地搭建npm私服】使用Verdaccio
前端·npm·node.js
从味书1 小时前
安装typescript时,npm install -g typescript报错
javascript·typescript·npm
lally.1 小时前
2025御网杯wp(web,misc,crypto)
前端·ctf
海绵不是宝宝8171 小时前
React+Springboot项目部署ESC服务器
前端·react.js·前端框架
前端小崔1 小时前
从零开始学习three.js(15):一文详解three.js中的纹理映射UV
前端·javascript·学习·3d·webgl·数据可视化·uv