Использовать CSS спрайты для списка (<li>) background image
Можно ли использовать спрайты CSS для фонового изображения списка? Обычно, я делаю спрайты с CSS следующим образом:
.sprite { background: url(sprite.png) no-repeat top left;}
.sprite-checkmark { background-position: 0 -24px; width: 24px; height: 23px; }
.sprite-comment { background-position: 0 -48px; width: 14px; height: 14px; }
<div class="sprite sprite-checkmark"></div>
Можно ли использовать спрайты для пуль типа <li> элементы? Есть CSS-свойства, называемые list-style-image и list-style-position, но я не уверен, как заставить его работать без существования таких свойств, как list-style-image-width и list-style-image-height также.
Спасибо.
Ответы
Ответ 1
Вы также можете использовать
li:before {
background:url(..) no-repeat -##px -##px;
width:##px;
height:##px;
display:block;
position:absolute;
content: " ";
top:##px;
left:##px;
}
и, таким образом, получить дополнительный элемент, добавленный в DOM, и предоставить фоновое изображение.
Ответ 2
вы можете использовать точно такой же метод для создания спрайтов CSS в List. Вот пример:
ul {
list-style-type:none;
}
ul li {
background:url(images/list-image.gif) no-repeat;
height:24px;
}
ul li.comment {
background-position: 0 -24px;
/*Override properties here if you wish */
}
И html
<ul>
<li class="comment">Test</li>
</ul>
Вам нужно будет удалить заполнение /margin по умолчанию с помощью соответствующих стилей CSS. Лично я не видел, как ранее использовались элементы стиля списка, но они знают, что это общее решение.
Ответ 3
Элементы фонового изображения элементов списка через спрайты имеют pittfalls из-за переменных высот и ширины. Подумайте о том, что пользователи увеличивают размер шрифта. Теперь ваша воображаемая ли высота становится более высокой, чем ожидалось, и ваши другие спрайт-изображения становятся видимыми. Наиболее полезно для списка и спрайтов, когда изображения выравниваются по левому краю. Укладка изображений по диагонали снизу слева направо направо дает больше шансов, чтобы другие элементы спрайта стали видимыми.
Для левых вертикально-центрированных изображений требуется фиксированная ширина внешнего элемента (пример 800px), а ширина изображений спрайтов становится такой шириной, умноженной на количество разных изображений. 10 различных меток отметки 800 px = 8000px широкий спрайт.
Графический пример:
|--------------- 800px -------------|
|--------------- 800px ------------|
+-------+----------------------------------------------------------------------+
| Img 1 | |
+-------+ |
| |
| |
| |
| +-------+ |
| | Img 2 | |
| +-------+ |
| |
| |
| |
| |
| +-------+
| | Img 3 |
+----------------------------------------------------------------------+-------+
Ответ 4
Внутри элемента списка вы делаете пустой пробел следующим образом:
<ul>
<li>
<span class="bullet"></span> Example text
</li>
</ul>
В вашем css вы так стилируете
.bullet
{
height: 10px;
width: 10px;
position: relative;
top:2px; /*to align vertically*/
display: inline-block;
overflow: hidden;
background-image: url(/sprite.png);
background-position: 0 -30px;
}
Это поможет решить проблему увеличения размера текста и выявления других разделов спрайта. Надеюсь, что это поможет.
Ответ 5
Вы можете решить это очень просто, разместив свое изображение на нижней части вашего спрайта без изображений справа.
Ответ 6
вы можете использовать стиль в ul, чтобы выполнить одно и то же.
ul {
list-style:square url(../images/whatever.png);
}
Ответ 7
Я думаю, что использование "традиционных" csssprites слишком рискованно, как указано в @Pro Backup.
Это был лучший компромисс для меня.
Вы помещаете изображение в формат base64 и резервный стандартный стиль для [действительно] старых браузеров. Таким образом, у вас есть только 1 запрос для css. Типичная закодированная пуля должна составлять всего пару сотен байт.
li
{
list-style: square;
list-style-image: url();
}
Показать: http://jsfiddle.net/VThLq/1/