используйте CSS-спрайты для фонового изображения list ()

можно ли использовать 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>

можно ли использовать спрайты для пуль элементов

  • ? Есть свойства CSS, называемые list-style-image и list-style-position, но я не уверен, как заставить его работать без наличия таких свойств, как list-style-image-width и list-style-image-height.

    спасибо.

  • 7 ответов


    вы также можете использовать

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

    и, таким образом, получите дополнительный элемент, добавленный в DOM, и дайте фоновое изображение.


    вы можете использовать точно такой же метод для выполнения 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. Лично я не видел, чтобы материал list-style-image использовался раньше, но знаю, что это общее решение.


    элементы списка фоновые изображения через спрайты имеют pittfalls, из-за переменных высот и ширины. Подумайте о пользователях, которые увеличивают размер шрифта. Теперь ваша воображаемая высота li становится более высокой, чем ожидалось, и ваши другие изображения спрайтов становятся видимыми. Наиболее полезны для списка и спрайтов, когда изображения выровнены слева вверху. Укладка изображений по диагонали снизу слева направо дает больше шансов предотвратить появление других элементов спрайта. Требуется левое вертикальное центрированное изображение фиксированная ширина внешнего элемента (пример 800px), и ширина спрайта изображений становится этой шириной, умножая количество различных изображений. 10 различных отметок времени 800 px = 8000px широкий спрайт.

    графический пример:

    |--------------- 800px -------------|
                                        |--------------- 800px ------------|
    
    +-------+----------------------------------------------------------------------+
    | Img 1 |                                                                      |
    +-------+                                                                      |
    |                                                                              |
    |                                                                              |
    |                                                                              |
    |                                   +-------+                                  |
    |                                   | Img 2 |                                  |
    |                                   +-------+                                  |
    |                                                                              |
    |                                                                              |
    |                                                                              |
    |                                                                              |
    |                                                                      +-------+
    |                                                                      | Img 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(../images/whatever.png);
    }
    

    Я думаю, что использование "традиционных" csssprites слишком рискованно - как указано @Pro Backup.

    Это был лучший компромисс для меня. Вы помещаете изображение в формат base64 и резервный стандартный стиль для [действительно] старых браузеров. Таким образом, у вас есть только 1 запрос на css. Типичная закодированная пуля должна составлять всего пару сотен байт.

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

    посмотреть это: http://jsfiddle.net/VThLq/1/