css:两个行内块元素和图片垂直居中对齐
  ndh0xMjNGcR6 2023年12月07日 26 0



目录

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


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

先看一段代码:

<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>

显示效果

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


发现一个很奇怪的现象:我们本来期待的是两个框对齐,表现却是错位的

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

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

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

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

如果两个元素都没有文本,同样是对齐的

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


尝试增加对齐属性

.middle {
  vertical-align: middle;
}

在第一个元素上增加

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

发现还是没有对齐,还是有一点点错位

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


尝试在第二个元素上增加

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

发现并没有居中对齐,有种失效的感觉

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


解决办法

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

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

表现如下

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

图片垂直居中问题

<style>
.box {
   background-color: green;
 }
</style>

<div class="box">
 <img class="image" src="./mm.jpg" alt="" />
</div>

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

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

实现图片垂直居中对齐

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

.image {
  display: block; 
}

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

.image {
  vertical-align: middle;
}

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

.box {
    line-height: 0;
}

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

.box {
    font-size: 0;
}

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

图片和文字垂直居中对齐

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

<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>

可以看到,默认情况下并没有实现垂直居中对齐

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

改造如下

<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>

实现效果如下

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

参考文章

  1. CSS深入理解vertical-align和line-height的基友关系


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年12月07日 0

暂无评论

推荐阅读
  E929ZvlRxyUs   2023年12月23日   37   0   0 前端url前端URL
ndh0xMjNGcR6