-->

use CSS sprites for list (
  • ) background image
  • 2019-02-05 11:45发布

    问题:

    Is it possible to use CSS sprites for the list background image? Normally, I render my sprites with CSS like this:

    .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.

    Thanks.

    回答1:

    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.



    回答2:

    you can use exactly the same method to do CSS sprites on a List. Here's a quick sample:

    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

    <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.



    回答3:

    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.

    A graphical example:

    |--------------- 800px -------------|
                                        |--------------- 800px ------------|
    
    +-------+----------------------------------------------------------------------+
    | Img 1 |                                                                      |
    +-------+                                                                      |
    |                                                                              |
    |                                                                              |
    |                                                                              |
    |                                   +-------+                                  |
    |                                   | Img 2 |                                  |
    |                                   +-------+                                  |
    |                                                                              |
    |                                                                              |
    |                                                                              |
    |                                                                              |
    |                                                                      +-------+
    |                                                                      | Img 3 |
    +----------------------------------------------------------------------+-------+
    


    回答4:

    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

    .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.



    回答5:

    You can solve this very simple by putting your image on the bottom of your sprite image with no images to the right.



    回答6:

    you can use a style in the ul to accomplish the same thing.

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


    回答7:

    I think using 'traditional' csssprites is too risky - as pointed out by @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.

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

    View it: http://jsfiddle.net/VThLq/1/