当前位置: 首页 > news >正文

css:两个行内块元素和图片垂直居中对齐

目录

    • 两个行内块元素垂直居中对齐
    • 图片垂直居中问题
    • 图片和文字垂直居中对齐
    • 参考文章

两个行内块元素垂直居中对齐

先看一段代码:

<style>
.box {width: 200px;height: 200px;line-height: 200px;font-size: 20px;text-align: center;display: inline-block;background-color: green;}
</style><div class="box"></div>
<div class="box">box</div>

显示效果
在这里插入图片描述
发现一个很奇怪的现象:我们本来期待的是两个框对齐,表现却是错位的

原因是:
一个inline-block元素,如果里面没有inline内联元素,或者overflow不是visible,则该元素的基线就是其margin底边缘,否则,其基线就是元素里面最后一行内联元素的基线。

所以第一个框的底部和后一个元素中的文字基线对齐了,

如果两个元素都有文本,则是对齐的

在这里插入图片描述

如果两个元素都没有文本,同样是对齐的
在这里插入图片描述
尝试增加对齐属性

.middle {vertical-align: middle;
}

在第一个元素上增加

<div class="box middle"></div>
<div class="box">box</div>

发现还是没有对齐,还是有一点点错位
在这里插入图片描述
尝试在第二个元素上增加

<div class="box"></div>
<div class="box middle">box</div>

发现并没有居中对齐,有种失效的感觉
在这里插入图片描述
解决办法

让第一个盒子对齐方式改为顶部或底部对齐

.top {vertical-align: top;
}
<div class="box top"></div>
<div class="box">box</div>

表现如下
在这里插入图片描述

图片垂直居中问题

<style>
.box {background-color: green;}
</style><div class="box"><img class="image" src="./mm.jpg" alt="" />
</div>

图片没有居中显示,底部多出了一个间隙

在这里插入图片描述

实现图片垂直居中对齐

方案一:修改图片元素为块级元素

.image {display: block; 
}

方案二:图片元素居中对齐

.image {vertical-align: middle;
}

方案三:父级元素行高改为0

.box {line-height: 0;
}

方案四:父级元素字体大小改为0

.box {font-size: 0;
}

在这里插入图片描述

图片和文字垂直居中对齐

一个很常见的需求,用户头像和用户名并排显示

<style>.box {background-color: green;}.image {border-radius: 50%;width: 30px;height: 30px;object-fit: cover;}.text {background-color: red;color: #fff;}
</style><div class="box"><img class="image" src="./mm.jpg" alt="" /><span class="text">我是一段文字</span>
</div>

可以看到,默认情况下并没有实现垂直居中对齐
在这里插入图片描述

改造如下

<style>.box {background-color: green;}.image {vertical-align: middle;border-radius: 50%;width: 30px;height: 30px;object-fit: cover;}.text {background-color: red;color: #fff;font-size: 12px;vertical-align: middle;}
</style><div class="box"><img class="image" src="./mm.jpg" alt="" /><span class="text">我是一段文字</span>
</div>

实现效果如下
在这里插入图片描述

参考文章

  1. CSS深入理解vertical-align和line-height的基友关系
http://www.lryc.cn/news/227852.html

相关文章:

  • 从0开始python学习-34.pytest常用插件
  • 初始MySQL(二)(表的增删查改)
  • SLAM从入门到精通(SLAM落地的难点)
  • 通过内网穿透快速搭建公网可访问的Spring Boot接口调试环境
  • 职业迷茫,我该如何做好职业规划
  • 数据结构----顺序栈的操作
  • web3 React Dapp书写订单 买入/取消操作
  • C++学习---信号处理机制、中断、异步环境
  • 机器学习——奇异值分解案例(图片压缩-代码简洁版)
  • 【Go入门】面向对象
  • Asp.Net Core 中使用配置文件
  • 深入理解JVM虚拟机第二十四篇:详解JVM当中的动态链接和常量池的作用
  • QGridLayout
  • 万能在线预约小程序系统源码 适合任何行业在线预约小程序+预约到店模式 带完整的搭建教程
  • Leetcode 2935. Maximum Strong Pair XOR II
  • [直播自学]-[汇川easy320]搞起来(4)看文档 查找设备(续)
  • WebSphere Liberty 8.5.5.9 (四)
  • UE特效案例 —— 角色刀光
  • 11. EPIC定时器
  • git-bash配置代理
  • 【ElasticSearch系列-07】ES的开发场景和索引分片的设置及优化
  • JavaWeb Day09 Mybatis-基础操作02-XML映射文件动态SQL
  • CV学习基础
  • 设计模式之禅之设计模式-原型模式
  • Spring的循环依赖问题
  • RT-DETR算法改进:更换损失函数DIoU损失函数,提升RT-DETR检测精度
  • 【ICE】2:基于webrtc的 ice session设计及实现
  • Vue组件传
  • 轻量封装WebGPU渲染系统示例<25>- 颜色附件数据更新替换(源码)
  • c语言练习第11周(1~5)