Вопрос по vertical-alignment, css – Выровнять изображение по вертикали

29

У меня есть div, который содержит изображение и тег p (см. Ниже). Я хочу выровнять изображение по центру div по вертикали в зависимости от того, сколько строк в абзаце. Выровнять по вертикалит работа. Я сейчас использую JavaScript, чтобы выяснить, сколько нужно добавить в margin-top, но лучше использовать CSS. Есть идеи?


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

Ваш Ответ

7   ответов
0

Як Псат веб поможет.

60

выравнивающий изображение по вертикали, а также изменяющий размер изображения, если онs выше (или шире), чем вмещающий ящик. Следовательно, поле и изображение могут быть любого размера без нарушения вертикального выравнивания. Кроме того, вы можете добавить левое поле к

 теги, чтобы они не были скрыты изображением.

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 

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>

Это прекрасное решение - спасибо, что поделились! Это работает хорошо, когда больше ничего не кажется. Jurgen
блестящий код спасибо Aziz
Хотелось бы, чтобы я проголосовал за это больше! Огромное спасибо :) Sebastian Hoitz
Хорошо, заправляя это в мой пояс для инструментов. Jamey
1

блок, плавающее: левое и вертикальное выравнивание: среднее. Или задайте ему высоту строки, равную высоте содержащего элемента.

1

лицы и встроенными элементами. Так как тег абзаца по умолчанию определяет элемент блока, он ничего не делает. Чтобы ваш текст выровнялся, как вы описываете, вы должны либо разделить ваш div на два контейнера, либо использовать таблицу. Вот'Хорошая страница, которая поможет вам немного лучше понять:Понимание вертикального выравнивания

11

Попробуйте установитьline-height атрибутp Элемент к высоте изображения, например:

div p {
  line-height: 18px;
}

Редактировать: Просто понял, что я неправильно понял вопрос и пропустил тот факт, чтоp будет многострочным. Один из вариантов - удалитьimg элемент в целом и установив его какbackground-image изp вместо этого сbackground-position изleft, center, Что-то вроде:

div p {
  background: transparent url(path/to/img) no-repeat left center;
  padding-left:30px; /* Set based on width of image */
}
Это хорошее решение. Однако в моем примере изображение изменится и не будет установленным изображением. jakeprzespo
Я также мог бы просто установить <p> к определенному классу динамически, который будет иметь разные изображения. jakeprzespo
Вы всегда можете установить атрибут background-image как встроенный стиль: <p style = "фоновое изображение: URL (динамически / генерируется / путь / к / IMG) ">Многоканальный </ Р> Luke Bennett
Это победилоне работать, если тыпытается стилизовать изображение (то есть: если у моего изображения есть рамка). WhyNotHugo
0

текст справа)

Если это так, вы могли бы просто вставить каждый элемент в свой собственный div ...

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

Думаю, что будет делать то, что тыпосле

Это победилоt вертикально выровнять их. WhyNotHugo
-1

добавлять

div img {
    float: left;
}
Будет ли это не только в левом верхнем углу? dbrien
Уже всплывает, возможно, следовало бы добавить, что в. У меня изображение с плавающей слева и р с поля слева. jakeprzespo

Похожие вопросы