垂直对齐图像

Posted

技术标签:

【中文标题】垂直对齐图像【英文标题】:Vertical-align image 【发布时间】:2010-12-03 23:56:55 【问题描述】:

我有一个 div,其中包含一个图像和一个 p 标签(见下文)。我想根据段落的行数垂直对齐 div 中间的图像。垂直对齐不起作用。我现在正在使用 javascript 来确定要添加多少到 margin-top,但宁愿使用 CSS。有什么想法吗?

<div>
    <img>
    <p>Multi-line</p>
</div>

【问题讨论】:

【参考方案1】:

这是纯 CSS,垂直对齐图像,如果图像比包含框更高(或更宽),还会缩小图像大小。因此,盒子和图像都可以是任意大小而不会破坏垂直对齐。此外,您可能希望为 &lt;p&gt; 标签添加左边距,以防止它们被图像隐藏。

CSS

/* Positioning */
.absoluteCenterWrapper 
    position: relative; /* Contains the image in the div */

.absoluteCenter  /* Aligns image vertically */
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;

.absoluteCenterWrapper p  /* Pushes <p> to edge of image */
    margin-left: 101px; /* Width of image */

.absoluteCenter  /* Specifies width of image to avoid overlap if image changes */
    width: 101px; /* Width of image */


/* Sizing - resizes down to avoid cutting off */
.absoluteCenter 
    max-height: 100%;
    max-width: 100%;


/* Making it "pretty" */
.absoluteCenterWrapper  margin: 1em; padding: 0.001em; /* <- Hack to contain margins */ outline: 1px solid red; 
.absoluteCenterWrapper p  margin-top: 1em; margin-bottom: 1em; padding-left: 1em;
<div class="absoluteCenterWrapper">
 <img class="absoluteCenter" src="">
 <p>Paragraph goes here.</p>
 <p>Paragraph goes here.</p>
</div>
<div class="absoluteCenterWrapper">
 <img class="absoluteCenter" src="">
 <p>Paragraph goes here.</p>
 <p>Paragraph goes here.</p>
 <p>Paragraph goes here.</p>
</div>

【讨论】:

这是一个漂亮的解决方案 - 非常感谢分享!它运作良好,但似乎没有其他办法。 点赞!作为记录,对我来说,只需使用 margin: auto; position: absolute; top: 0; bottom: 0; 就足够了,我将图像放在绝对包装器中,而不是相对包装器。 absoluterelative 会导致孩子的行为方式相同,因此可以接受。至于排除max-height/max-width,只有当您知道您的图像永远比容器更宽/更高时才有效。把它放在里面也没有什么坏处。安全总比后悔好:P 我需要添加left:0;right:0;。我猜是因为直接容器没有指定宽度?!无论如何,也许它可以帮助某人。 很好,把它塞进我的工具带里。【参考方案2】:

尝试将p元素的line-height属性设置为图片的高度,例如:

div p 
  line-height: 18px;

编辑: 刚刚意识到我误读了问题并错过了p 将是多行的事实。尝试的一种选择是完全删除 img 元素并将其设置为 pbackground-image,而不是 background-positionleft, center。比如:

div p 
  background: transparent url(path/to/img) no-repeat left center;
  padding-left:30px; /* Set based on width of image */

【讨论】:

这是一个很好的解决方案。但是在我的示例中,图像会发生变化,并且不会是固定图像。 您始终可以将 background-image 属性设置为内联样式:

多行

我也可以将

动态设置为具有不同图像的特定类。

如果您尝试设置图像样式(即:如果我的图像有边框),这将不起作用。【参考方案3】:

也许Jak psát web 的解决方案会有所帮助。

【讨论】:

【参考方案4】:

CSS 垂直对齐属性仅适用于表格单元格和内联元素。由于段落标签默认指定一个块元素,它什么也不做。为了使您的文本按照您的描述对齐,您必须将 div 分成两个容器或使用表格。这是一个很好的页面,可以帮助您更好地理解:Understanding vertical-align

【讨论】:

【参考方案5】:

给图像显示:block,float:left和vertical-align:middle。或者,给它一个等于包含元素的行高。

【讨论】:

【参考方案6】:

这是一种两栏式的工作吗? (左边是图片,右边是文字)

如果是这样,您当然可以将每个元素粘贴到自己的 div 中...

<div>
    <div style="width:100; float:left"><img /></div>
    <div style="width:100; float:left"><p>multiline</p></div>
</div>

认为那会做你所追求的

【讨论】:

这不会垂直对齐它们。【参考方案7】:

添加

div img 
    float: left;

【讨论】:

已经是浮动的,也许应该添加进去。我的图像向左浮动,而 p 的边距向左。 这不会只保留在左上角吗?

以上是关于垂直对齐图像的主要内容,如果未能解决你的问题,请参考以下文章

垂直对齐图像

打破容器时垂直对齐图像

垂直对齐图像和多行文本

Bootstrap 垂直对齐图像

如何在背景图像上垂直对齐文本? [复制]

具有垂直对齐图像的自定义 UITabBar