簡體   English   中英

使用CSS在div中進行圖像垂直對齊

[英]Image vertical alignment inside a div with CSS

腳本

我正在嘗試使用表格單元格方法( '6種使用CSS垂直居中的方法 '@Vanseo Design)在div垂直對齊img

<style>
    .container{border: solid 1px #000;display:table;}
    .contentItem{display:table-cell;vertical-align:middle;}
    .contentImg{float:left; width: 50px; margin: 3px;}
    .contentDiv{width: 400px; padding: 10px 2px 2px 2px;}
</style>
<div class="container">
    <div class="contentItem">
        <img class="contentImg" title="test" src="tv1.gif"/>
        <div class="contentDiv">Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi vel scelerisque enim.</div>
    </div>
</div>

問題

它根本行不通。 這是一個(不是)runnig jsFiddle 示例

事實

  • 我正在使用Chrome
  • 圖片寬度必須設置為固定值(例如50px)
  • 圖像高度是可變的,在加載圖像之前未知
  • 無法刪除contentDiv div標簽。 實際上,它包含具有動態數據的復雜結構,而不是簡單的文本。

嘗試這個

<div class="container">
    <div class="contentItem">
        <img class="contentImg" title="test" src=""/>
        Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi vel scelerisque enim.
    </div>
</div>

CSS

.container{border: solid 1px #000;display:table;}
.contentItem{display:table-cell;vertical-align:middle;}
.contentImg{float:left; width: 50px; margin: 3px;vertical-align:text-top;}
.contentDiv{width: 400px; padding: 10px 2px 2px 2px;}

如果您無法擺脫div,則只需更改CSS

.contentDiv{width: 400px; padding: 0px 2px 2px 2px;}

浮動圖像時,垂直對齊不起作用。 如果從圖像中刪除浮點,然后將text div設置為inline-block元素,則對齊將起作用:

.contentImg{width: 50px; margin: 3px;}
.contentDiv{width: 400px; padding: 10px 2px 2px 2px; display:inline-block;}

http://jsfiddle.net/Z8GaT/1/

或者簡單地:

.yourClass{
     position: relative;
     top: 50%;
     margin-top: - "the height of your image" / 2+px;
 }

請注意,如果不清楚,則邊緣上限值應減去圖像的高度除以2。

在這里查看演示

去掉

.contentDiv{width: 400px; padding: 10px 2px 2px 2px;}

可能這可以解決您的問題:)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM