Html 将 CSS 精灵用于列表 (<li>) 背景图像
声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow
原文地址: http://stackoverflow.com/questions/2381789/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me):
StackOverFlow
use CSS sprites for list (<li>) background image
提问by Emmett
Is it possible to use CSS sprites for the list background image? Normally, I render my sprites with CSS like this:
是否可以将 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>
Is it possible to use sprites for the bullets of <li> elements? There are CSS properties called list-style-image, and list-style-position, but I'm not sure how to make it work without the existence of properties like list-style-image-width and list-style-image-height as well.
是否可以将精灵用于 <li> 元素的项目符号?有名为 list-style-image 和 list-style-position 的 CSS 属性,但我不确定如何在不存在 list-style-image-width 和 list-style-image-height 等属性的情况下使其工作以及。
Thanks.
谢谢。
回答by designitsimple
You can also use
你也可以使用
li:before {
background:url(..) no-repeat -##px -##px;
width:##px;
height:##px;
display:block;
position:absolute;
content: " ";
top:##px;
left:##px;
}
and thus get an additional element added to the DOM and give that the background image.
从而将额外的元素添加到 DOM 并提供背景图像。
回答by Hux
you can use exactly the same method to do CSS sprites on a List. Here's a quick sample:
您可以使用完全相同的方法在列表上执行 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 */
}
And the html
和 html
<ul>
<li class="comment">Test</li>
</ul>
You'll have to remove the default padding/margin with the appropriate CSS styles. Personally i've not seen the list-style-image stuff being used before but know the above is a common solution.
您必须使用适当的 CSS 样式删除默认的填充/边距。就我个人而言,我之前没有看到过使用 list-style-image 的东西,但知道上面是一个常见的解决方案。
回答by Pro Backup
List elements background images via sprites have pittfalls, due to variable heights and widths. Think of users that enlarge their font size. Now your imagined li height becomes heigher than expected and your other sprite images become visible. Most useful for list and sprites are when the images are top left aligned. Stacking images diagonally from bottom left to top right gives most chance to prevent other sprite elements to become visible. Left vertical centered images required fixed width of the outer element (example 800px), and the width of the sprite images becomes that width, times the number of different images. 10 different tick marks times 800 px = 8000px wide sprite.
由于高度和宽度可变,通过精灵列表元素背景图像存在缺陷。想想放大字体大小的用户。现在你想象的 li 高度变得比预期的要高,你的其他精灵图像变得可见。当图像左上对齐时,对列表和精灵最有用。从左下角到右上角对角堆叠图像可以最大程度地防止其他精灵元素变得可见。左垂直居中的图像需要固定宽度的外部元素(例如 800 像素),精灵图像的宽度变为该宽度,乘以不同图像的数量。10 个不同的刻度线乘以 800 像素 = 8000 像素宽的精灵。
A graphical example:
图形示例:
|--------------- 800px -------------| |--------------- 800px ------------| +-------+----------------------------------------------------------------------+ | Img 1 | | +-------+ | | | | | | | | +-------+ | | | Img 2 | | | +-------+ | | | | | | | | | | +-------+ | | Img 3 | +----------------------------------------------------------------------+-------+
回答by ctrombley
Inside your list item you make an empty span like this:
在您的列表项中,您可以像这样创建一个空跨度:
<ul>
<li>
<span class="bullet"></span> Example text
</li>
</ul>
In your css you style like this
在你的 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;
}
This will help solve the issue of users increasing text size and revealing other sections of the sprite. Hope that can help.
这将有助于解决用户增加文本大小和显示精灵其他部分的问题。希望能有所帮助。
回答by user3004751
You can solve this very simple by putting your image on the bottom of your sprite image with no images to the right.
您可以通过将图像放在精灵图像的底部而右侧没有图像来解决这个非常简单的问题。
回答by Simon_Weaver
I think using 'traditional' csssprites is too risky - as pointed out by @Pro Backup.
我认为使用“传统”csssprites 风险太大——正如@Pro Backup 所指出的那样。
This was the best compromise for me. You put the image in base64 format and a fallback standard style for [really] old browsers. That way you only have 1 request for css. A typical encoded bullet should only be a couple hundred bytes.
这对我来说是最好的妥协。您将图像以 base64 格式和 [真正] 旧浏览器的后备标准样式放置。这样你只有 1 个 css 请求。一个典型的编码子弹应该只有几百个字节。
li
{
list-style: square;
list-style-image: url();
}
View it:http://jsfiddle.net/VThLq/1/
回答by gumbar
you can use a style in the ul to accomplish the same thing.
你可以在 ul 中使用一个样式来完成同样的事情。
ul {
list-style:square url(../images/whatever.png);
}