Подводя итог остальным ответам здесь - если вы хотите более точно контролировать пространство между маркерами и текстом в <li>
элементе списка, вы можете выбрать следующие варианты:
(1) Используйте фоновое изображение:
<style type="text/css">
li {
list-style-type:none;
background-image:url(bullet.png);
}
</style>
<ul>
<li>Some text</li>
</ul>
Преимущества:
- Вы можете использовать любое изображение для пули
- Вы можете использовать CSS
background-position
для позиционирования изображения практически в любом месте по отношению к тексту, используя пиксели, ems или%
Недостатки:
- Добавляет дополнительный (хотя и небольшой) файл изображения на вашу страницу, увеличивая вес страницы
- Если пользователь увеличит размер текста в своем браузере, маркер останется в исходном размере. С увеличением размера текста он также, вероятно, будет становиться все более неуместным.
- Если вы разрабатываете «отзывчивый» макет, используя только проценты для ширины, может быть трудно получить маркер именно там, где вы хотите, в диапазоне ширины экрана
2. Используйте отступы на <li>
теге
<style type="text/css">
ul {padding-left:1em}
li {padding-left:1em}
</style>
<ul>
<li>Some text</li>
</ul>
Преимущества:
- Нет изображения = 1 файл меньше для загрузки
- Регулируя дополнение на
<li>
, вы можете добавить столько , сколько заемных горизонтального пространства между маркером и текстом , как вам нравится
- Если пользователь увеличивает размер текста, интервал и размер маркера должны пропорционально масштабироваться
Недостатки:
- Невозможно переместить маркер ближе к тексту, чем браузер по умолчанию
- Ограничено формами и размерами встроенных типов маркеров CSS
- Пуля должна быть того же цвета, что и текст
- Нет контроля над вертикальным расположением пули
(3) обернуть текст в дополнительный <span>
элемент
<style type="text/css">
li {
padding-left:1em;
color:#f00; /* red bullet */
}
li span {
display:block;
margin-left:-0.5em;
color:#000; /* black text */
}
</style>
<ul>
<li><span>Some text</span></li>
</ul>
Преимущества:
- Нет изображения = 1 файл меньше для загрузки
- Вы получаете больший контроль над положением маркера, чем с опцией (2) - вы можете переместить его ближе к тексту (хотя, несмотря на все мои усилия, кажется, вы не можете изменить вертикальное положение, добавив
padding-top
к<span>
. Кто-то может иметь Обходной путь для этого, хотя ...)
- Пуля может быть другого цвета для текста
- Если пользователь увеличивает размер текста, маркер должен масштабироваться пропорционально (при условии, что вы задаете отступы и поля в ems, а не в px).
Недостатки:
- Требуется дополнительный не семантический элемент (это, вероятно, приведет к потере большего количества друзей в SO, чем в реальной жизни;), но это раздражает тех, кому нравится, когда их код является максимально компактным и эффективным, и это нарушает разделение представления и контента. что HTML / CSS должен предложить)
- Нет контроля над размером и формой пули
Здесь мы надеемся на некоторые новые функции в стиле списка в CSS4, чтобы мы могли создавать более умные маркеры, не прибегая к изображениям или дополнительной разметке :)