使用CSS精灵技术来设置列表(<li>)的背景图片

35

是否可以使用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>元素的项目符号?有一些名为list-style-image和list-style-position的CSS属性,但如果没有类似于list-style-image-width和list-style-image-height的属性,我就不确定该如何使其工作。

谢谢。

7个回答

53

你也可以使用

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

因此,会向DOM中添加一个额外的元素,并将其设为背景图片。


1
虽然我在概念上不喜欢添加DOM元素,但这个方法非常有效且实现干净。只要我不必支持IE7,我就会使用它。http://caniuse.com/#search=:before - jon skulski
如果你必须支持IE7,那么IE8.js可以解决这个问题。http://code.google.com/p/ie7-js/ - jsims281
我喜欢它!感谢这个代码片段!在这里,原生地可以在IE8中运行。 - kernel

18

你可以使用完全相同的方法在列表上进行CSS sprites。这是一个快速示例:

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样式来去除默认的填充/边距。个人而言,我以前并没有见过使用list-style-image的方式,但知道上述方法是一种常见解决方案。


10
通过精灵图设置列表元素的背景图像存在缺陷,由于可变的高度和宽度。考虑到字体大小的放大,那么您想象中的li的高度就会变高,而其他的精灵图像就会变得可见。列表和精灵最有用的是当图像是左上对齐时。将图像从左下到右上对角线堆叠可以最大程度地防止其他精灵元素变得可见。 左垂直居中的图像需要外部元素(例如800px)的固定宽度,精灵图像的宽度变为该宽度乘以不同图像的数量。10个不同的勾号乘以800 px = 8000px宽的精灵。
一个图形的例子:
|--------------- 800px -------------|
                                    |--------------- 800px ------------|
+-------+----------------------------------------------------------------------+ | Img 1 | | +-------+ | | | | | | | | +-------+ | | | Img 2 | | | +-------+ | | | | | | | | | | +-------+ | | Img 3 | +----------------------------------------------------------------------+-------+

理论上,如果您知道列表项的高度不会超过某个特定大小,那么您可以将它们垂直堆叠。图像会变小,但我不知道这会对文件大小产生多大影响。 - THEtheChad

8
在您的列表项中,您可以像这样创建一个空的
<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;
}

这将有助于解决用户增大文本大小并显示精灵的其他部分的问题。希望能对您有所帮助。

1

您可以通过将图像放在精灵图像的底部,并且右侧没有其他图片来解决这个非常简单的问题。


0

你可以在ul中使用样式来实现相同的效果。

ul {
list-style:square url(../images/whatever.png);
}

3
但是如何使用精灵图在这种方法中呢? - Lea Cohen

0

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

这对我来说是最好的妥协方案。 您可以将图像以base64格式放置,并为[真正]旧的浏览器提供备用标准样式。这样,您只需要1个css请求。典型的编码子弹应该只有几百字节。

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

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


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接