为列表(<li>)使用CSS精灵背景图片

有没有可能使用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属性称为列表样式图像和列表样式的位置,但我不知道如何使它的工作没有像列表样式图像宽度和列表样式图像高度的属性的存在以及。

谢谢。

你也可以使用

 li:before { background:url(..) no-repeat -##px -##px; width:##px; height:##px; display:block; position:absolute; content: " "; top:##px; left:##px; } 

从而获得添加到DOM的附加元素并给出背景图像。

你可以使用完全相同的方法在List上做CSS精灵。 这是一个快速示例:

 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> 

您必须使用适当的CSS样式去除默认的填充/边距。 就我个人而言,我还没有看到之前使用的列表式图像的东西,但知道上述是一个常见的解决scheme。

列表元素背景图像通过精灵有pittfalls,由于可变的高度和宽度。 考虑放大他们的字体大小的用户。 现在你的想象里的高度变得比预期的高,你的其他精灵图像变得可见。 对列表和精灵最有用的是当图像左上alignment时。 从左下angular到右上angular对angular线堆叠图像给了防止其他精灵元素变得可见的绝佳机会。 左侧竖直居中的图像需要外部元素的固定宽度(例如800px),并且精灵图像的宽度变成该宽度乘以不同图像的数量。 10个不同的刻度标记乘以800px = 8000px宽的精灵。

一个graphics例子:

 | --------------- 800px ------------- |
                                     | --------------- 800px ------------ |

 + ------- + ----------------------------------------- ----------------------------- +
 |  Img 1 |  |
 + ------- + |
 |  |
 |  |
 |  |
 |  + ------- + |
 |  | 图2 |  |
 |  + ------- + |
 |  |
 |  |
 |  |
 |  |
 |  + ------- +
 |  | 图3 |
 + ------------------------------------------------- --------------------- + ------- +

在你的列表项目中,你可以像这样做一个空的跨度:

 <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; } 

这将有助于解决用户增加文本大小和揭示精灵其他部分的问题。 希望可以帮助。

你可以通过将你的图像放在你的精灵图像的底部而没有右边的图像来解决这个问题。

你可以在ul中使用一种风格来完成同样的事情。

 ul { list-style:square url(..http://img.dovov.comwhatever.png); } 

我认为使用“传统”csssprites风险太大了 – 正如@Pro Backup所指出的那样。

这对我来说是最好的妥协。 您将图像设置为base64格式,并为[真正的]旧浏览器设置后备标准样式。 这样,你只有1请求的CSS。 一个典型的编码子弹应该只有几百个字节。

 li { list-style: square; list-style-image: url(); } 

查看: http : //jsfiddle.net/VThLq/1/