垂直对齐图像(Vertical-align image)

2019-07-20 23:00发布

我有一个包含一个图像和AP标签(如下所示),一个div。 我要对齐的图像在垂直方向的div中间取决于段落多少行是。 垂直对齐不起作用。 我使用JavaScript现在找出多少添加到边距,但宁愿使用CSS。 有任何想法吗?

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

Answer 1:

尝试设定line-height的的属性p元件到图像,例如高度:

div p {
  line-height: 18px;
}

编辑:刚刚意识到我误解了问题,错过了事实p会是多行。 一个选项来尝试在除去img共元件并将其设置为所述background-image的的p代替,具有background-positionleft, center 。 就像是:

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


Answer 2:

这是纯CSS,垂直对准图像,并且还调整图像大小下来,如果它比容纳箱高(或宽)。 因此,这个盒和图像都可以是不破坏垂直取向的任何尺寸。 此外,您可能希望将左边距添加到<p>标签,让他们从图像被隐藏。

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> 



Answer 3:

给所述图像显示:块,浮动:左,垂直对齐:中间。 或者,给它一个线高度等于包含元素的。



Answer 4:

CSS的垂直对齐属性只在工作表单元格和内联元素。 由于段落标记在默认情况下指定一个块级元素,它什么都不做。 为了让你的文字,你描述要对齐,你要么有你的div分成两个容器或使用一个表。 这里有一个很好的页面,以帮助您了解更好一点: 了解垂直对齐



Answer 5:

它是一种两列的工作? (图片左侧,文本右侧)

如果是这样,你可以肯定只是坚持每个元素在它自己的DIV ...

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

认为会对你以后在做什么



Answer 6:

也许在解决方案的Jak PSAT网络将帮助。



Answer 7:

div img {
    float: left;
}


文章来源: Vertical-align image