Как вы центрируете пользовательское изображение по вертикали в элементе <li> в разных браузерах?

Дизайн веб-сайта, над которым я работаю, предусматривает создание пользовательского изображения в списках вместо маркера. Использование изображения - это нормально, но у меня возникли трудности с обеспечением его центрирования по тексту элемента списка во всех браузерах. Кто-нибудь знает стандартное решение для этого?

Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Введение в CSS
Введение в CSS
CSS является неотъемлемой частью трех основных составляющих front-end веб-разработки.
Как выровнять Div по центру?
Как выровнять Div по центру?
Чтобы выровнять элемент <div>по горизонтали и вертикали с помощью CSS, можно использовать комбинацию свойств и значений CSS. Вот несколько методов,...
Навигация по приложениям React: Исчерпывающее руководство по React Router
Навигация по приложениям React: Исчерпывающее руководство по React Router
React Router стала незаменимой библиотекой для создания одностраничных приложений с навигацией в React. В этой статье блога мы подробно рассмотрим...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
CSS: FlexBox
CSS: FlexBox
Ранее разработчики использовали макеты с помощью Position и Float. После появления flexbox сценарий полностью изменился.
4
0
9 767
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Вы пробовали добавить следующий код в свой файл CSS?

li
{
   background-image: URL('custom.png');
   background-repeat: no-repeat;
   background-position: center;
}

Пользовательский маркер не является фоновым изображением элемента li.

Dereckson 27.03.2014 14:21
Ответ принят как подходящий

Если вы имеете в виду использование настраиваемого маркера изображений для своего списка, это код, который вы захотите использовать, он будет центрирован по вертикали. Я предполагаю, что изображение пули имеет размер 12 на 12 пикселей.

ul li {
  background: transparent url(/link/to/custom/bullet.gif) no-repeat 0 50%; 
  padding-left: 18px; 
}

Единственная проблема заключается в том, что иногда в длинных многострочных списках это выглядит странно. В этом случае лучше всего назначить положение фона небольшим отступом сверху и слева (т.е. без повтора 0 7 пикселей).

ура, Брюс

установите определенную высоту строки для элемента li и вертикальное выравнивание изображения .. сработало для меня

li { height: 150px; line-height: 150px; }
li img { vertical-align: middle; }

и HTML-код

<li><img src = "myimage.jpg" /></li>

если вы хотите адаптировать изображение к нестандартному размеру, сохранив соотношение

li img { max-width: 150px; max-height: 150px; width: auto; height: auto; }

Другие вопросы по теме