Image d'alignement Vertical
J'ai un div qui contient une image et une balise p (Voir ci-dessous). Je veux aligner l'image au milieu de la div verticalement en fonction du nombre de lignes du paragraphe. L'alignement Vertical ne fonctionne pas. J'utilise JavaScript en ce moment pour comprendre combien ajouter à margin-top, mais je préfère utiliser CSS. Des idées?
<div>
<img>
<p>Multi-line</p>
</div>
7 réponses
, Essayez de régler line-height
attribut de la p
élément à la hauteur de l'image, par exemple:
div p {
line-height: 18px;
}
Edit: Je viens de réaliser que j'ai mal lu la question et manqué le fait que p
serait multi-ligne. Une option à essayer est de supprimer complètement l'élément img
et de le Définir comme background-image
du p
à la place, avec un background-position
de left, center
. Quelque chose comme:
div p {
background: transparent url(path/to/img) no-repeat left center;
padding-left:30px; /* Set based on width of image */
}
C'est du CSS pur, aligne verticalement l'image et redimensionne également l'image si elle est plus grande (ou plus large) que la boîte contenant. Ergo, la boîte et l'image peuvent tous deux être n'importe quelle taille sans casser l'alignement vertical. En outre, vous pouvez ajouter une marge de gauche aux balises <p>
pour les empêcher d'être masquées par l'image.
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>
Donne l'affichage de l'image: block, float: left et vertical-align: middle. Ou, donnez-lui une hauteur de ligne égale à celle de l'élément contenant.
Les attributs d'alignement vertical CSS ne fonctionnent que sur les cellules de table et les éléments en ligne. Puisque la balise de paragraphe spécifie un élément de bloc par défaut, elle ne fait rien. Pour que votre texte soit aligné comme vous le décrivez, vous devez soit séparer votre div en deux conteneurs, soit utiliser une table. Voici une bonne page pour vous aider à comprendre un peu mieux: Comprendre vertical-align
Est-ce une sorte de travail à deux colonnes? (image à gauche, texte à droite)
Si c'est le cas, vous pourriez sûrement simplement coller chaque élément dans sa propre div...
<div>
<div style="width:100; float:left"><img /></div>
<div style="width:100; float:left"><p>multiline</p></div>
</div>
Pensez que cela ferait ce que vous recherchez