Храните мелкие картинки в CSS

    Храните мелкие картинки, которые нельзя засунуть в спрайты, в data:image base64 в CSS — это экономит кучу запросов к вебсерверу.

    Кодируем изображение в base64 с помощью онлайн сервисов, вроде сервиса от DailyCoding (очень удобно, ничего лишнего).
    Кладем получившуюся строку в CSS файл, заменяя «ТИП» на MIME-тип вашего изображения — jpeg/png/gif или (OMG!) bmp и «КОД» на нужную строку в base64:

    .some_background {
    	background-image: url("data:image/ТИП;base64,КОД");
    }

    Теперь можно смело подключать нужному элементу стиль some_background и наслаждаться двумя запросами к вебсерверу (html + css), вместо трех (html + css + изображение).

    Пример реализации с изображениями:
    images.html — 361 байт
    images/images.css — 305 байт
    images/test1.png — 1 600 байт
    images/test2.png — 1 143 байт
    Итого — 3 409 байт


    Пример реализации с base64.
    base64.html — 361 байт
    images/base64.css — 3 991 байт
    Итого — 4 352 байт


    Пример работы готового инструмента Jammit:
    (Google Chrome, ~60 Мбит/сек):

    До (102 запроса, 73,23 КБ передано, 3.41 сек):
    image

    После (2 запроса, 153,88 КБ передано, 0,94 сек):
    image

    Плюсы:
    • уменьшение числа запросов к вебсерверу;
    • меньшее засорение кеша пользователя;
    • иногда уменьшение результативного объема изображения на больших файлах.

    Минусы:
    • сложность обновления изображений;
    • иногда незначительное увеличение результативного объема изображения на мелких файлах.

    Непонятности (непонятно, плюс это или минус):
    • Internet Explorer 5, 6 и 7 не добавляли в друзья base64, но в IE8 работает нормально. Ее можно включить, но не рекомендую это делать, лучше использовать mhtml (спасибо vitosik)

    Мне кажется, что увеличение объема CSS файла лучше, чем лишний запрос к вебсерверу, поскольку по-умолчанию браузеры открывают в среднем 8 паралленьных соединений к вебсерверу, а 50—70 изображений это уже очередь, а кто любит очереди? :)

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

    Для автоматического упаковывания изображений в base64 есть онлайн сервис duris.ru, но можно использовать и PHP скрипт с регуляркой: (спасибо Serator)
    <?php
    echo preg_replace('/images\/[-\w\/\.]*/ie','"data:image/".((substr("\\0",-4)==".png")?"png":"gif").";base64,".base64_encode(file_get_contents("\\0"))',file_get_contents('style.css'));
    ?>

    Он делает из такого CSS файла:
    * {
    	padding:0;
    	margin:0;
    }
    html {
    	display:table;
    	width:100%;
    	height:100%;
    }
    body {
    	margin:auto 0;
    	overflow-y:scroll;
    	background:hsl(0,0%,30%) url(images/background.svg) no-repeat;
    
    }
    .px_sort_0{background:url(images/px/arrow-090-small.png)}
    .px_sort_1{background:url(images/px/arrow-270-small.png)}/* margin:0 5px; */
    .px_status_0{background:url(images/px/minus-circle-frame.png);cursor:pointer}
    .px_status_1{background:url(images/px/plus-circle-frame.png);cursor:pointer}
    .px_delete{background:url(images/px/cross-circle-frame.png);cursor:pointer}
    .px_help{background:url(images/px/question-frame.png);cursor:help}
    .px_info{background:url(images/px/information-frame.png);cursor:help}
    .px_return{background:url(images/px/arrow-skip-180.png);cursor:pointer}
    .px_watch{background:url(images/px/eye.png);cursor:pointer}
    .px_home{background:url(images/px/home.png)}
    [data-beforeAddContent]:before {
    	content:attr(data-beforeAddContent);
    	display:block;
    	color:red;
    	width:100px;
    	height:16px;
    	border:10px solid black;
    }

    такой:
    * {
    	padding:0;
    	margin:0;
    }
    html {
    	display:table;
    	width:100%;
    	height:100%;
    }
    body {
    	margin:auto 0;
    	overflow-y:scroll;
    	background:hsl(0,0%,30%) url() no-repeat;
    }
    .px_sort_0{background:url()}
    .px_sort_1{background:url()}/* margin:0 5px; */
    .px_status_0{background:url();cursor:pointer}
    .px_status_1{background:url();cursor:pointer}
    .px_delete{background:url();cursor:pointer}
    .px_help{background:url();cursor:help}
    .px_info{background:url();cursor:help}
    .px_return{background:url();cursor:pointer}
    .px_watch{background:url();cursor:pointer}
    .px_home{background:url()}
    [data-beforeAddContent]:before{
    	content:attr(data-beforeAddContent);
    	display:block;
    	color:red;
    	width:100px;
    	height:16px;
    	border:10px solid black;
    }


    Для Ruby on Rails есть примочка Jammit, которая упаковывает изображения в CSS, а так же делает кучу других плюшек (спасибо vitosik).
    Поделиться публикацией
    Похожие публикации
    AdBlock похитил этот баннер, но баннеры не зубы — отрастут

    Подробнее
    Реклама
    Комментарии 129
    • +15
      Насколько я знаю, чужие посты публиковать нельзя.
      • +1
        Было бы хорошо, если бы вы написали точно, работает ли это в IE6/7; в противном случае использование этого приема сильно ограничено.

        Еще интересно, не падает ли скорость загрузки страницы при повсеместном использовании этого приема. Ведь обычные картинки браузер кеширует, а сохраненные в css — вряд ли.
        • +12
          Так весь CSS кешируется.
        • +2
          К сожалению, в IE6-7 работать не будет, понадобится бубен.
          • 0
            или так duris.ru
            • +1
              Проверил — в 5, 6 и 7 действительно не работает, добавил костыль в топик. Спасибо.
              • +6
                Зачем пятый то? :)
                • +4
                  Что бы список больше был :)
                  • +6
                    Но если это и в пятом заработало после костыля — вы «злобный гений» верстки :)
                  • +4
                    Всмысле скорее «зачем шестой» :) Да и седьмой уже с приятной периодичностью сдает позиции.
                    • +3
                      С шестеркой столько воспоминаний *умиленно*
                • 0
                  Я правда написал инже в каментах, но еще и здесь продублирую, для ie7 можно использовать mhtml — у него с ним проблем не будет.
                • 0
                  Универсальнее хранить одной картинкой и смещать бэкграунд, как в JQueryUI.
                  • 0
                    К сожалению, не всегда такое возможно :(
                    • 0
                      Можно пример картинки, который нельзя засунуть в спрайт?
                      • +4
                        тянущиеся бекграунды?
                        • 0
                          А какие с ними проблемы? Я засовывал тянущиеся в спрайты.
                          • 0
                            Про Clip написали ниже — не везде работает, что плохо.
                            • 0
                              Я не про clip. Просто частенько элементы для которых используется бэкграунд с repeat-x, ограничены по высоте. В таком случае можно сложить в пачку несколько таких бэкграундов, в один спрайт, в который к тому же можно вставить и другие изображения.
                            • 0
                              Это вам не border-radius, которым как правило можно принебречь в IE.
                              • 0
                                А какие проблемы со спрайтами в IE?
                                • +1
                                  PIE легко обеспечит border-radius в IE.
                            • +1
                              Бекграунд 20х20 пикселей, repeat-x bottom для контейнера 100x100 пикселей. И таких несколько разных. Можно конечно использовать CSS свойство clip, но Internet Explorer такой Internet Explorer…
                              • +1
                                Согласен с Вами и Psih'ом. Действительно не случай для спрайтов
                                • 0
                                  Какая проблема? Ставим бэкграунд в самый верх спрайта, задаём положение отступом.

                                  Не, я не спорю, что такие варианты бывают, но они очень редки.
                                  • 0
                                    У меня 5 разных бэкграундов (3 тени и 2 bottom фона, все repeat-x). Что делать?
                                    • +1
                                      Панацея со вкусом Firefox'а :)
                                      • 0
                                        Самый главный вопрос в максимальной высоте элементов, к которым применяются эти фоны. Если это нечто невысокое (типа заголовков и других элементов), то вполне можно упаковать в спрайт.
                                    • 0
                                      И какие проблемы c clip? в IE он прекрасно работает, просто с маленькой особеностью. Для пнг (с фильтрами) часто использую. А проблема в запятых — уберите запятые, во всех браузерах не сломается а в IE заработает
                                • 0
                                  Это назвается спрайты и это действительно на данный момент очень Хороший способ!
                                  • 0
                                    Не подходит для анимированных гифов.
                                  • 0
                                    так вроде же говорится о
                                    мелких картинках, которые нельзя засунуть в спрайты
                                    • –1
                                      На сколько мелких? В спрайтах позиционирование с точностью в 1px.
                                  • 0
                                    Хз, насколько это целесообразно. Время на разработку увеличивается (время = деньги), а эффекта почти нет. Но прикольно:)
                                    • +1
                                      Вам явно слово «оптимизация» не знакомо. Экономия запросов к серверу это святое. Мы например в продакшен версиях всегда спецальными самописными скриптами собираем минимизированную версию из девелоперской. В итоге если открыть исходный код, то там в секции голова будут все стили в разделе, все скрипты в разделе и дальше тело с ногами, всё без переносов строк, выглядит стрёмно, но работает быстро. Запросы делаются только на необходимые картинки непосредственно в теле, которые нет смысла кодировать в base64, хотя будь моя воля я бы к одному запросу на сервер всё сводил.
                                      • 0
                                        Грандиозность положительного эффекта растет пропорционально количеству мелких изображений.
                                        • +1
                                          Очень зря, что автор не привел реальный пример, чтобы все увидели, что пользоваться таким способом нужно очень осторожно.

                                          Даже на маленькую картинку вы полчите кода в несколько метров, сильно сомневаюьс, что это украсит Ваш css файл.
                                          • +12
                                            • –2
                                              Я про код писал! А не про конечный результат.
                                              • +1
                                                Насчет «нескольких метров» для маленькой картинки вы сильно преувеличиваете, посмотрите в примерах, что я скинул, а скорость загрузки сильно выше + gzip в помощь
                                                • –1
                                                  > Насчет «нескольких метров» для маленькой картинки вы сильно преувеличиваете

                                                  Специально замерил, для картинки телефончика, что ниже при размере шрифта 11 pt нужно: почти 6 метром кода

                                                  Преувеличил?
                                                  • 0
                                                    Ок, согласен насчет осторожности при использовании такого метода, но в приведенных мною примеров гигантского размера я не увидел.
                                                    • –1
                                                      А Вы код смотрели? Первая же галочка тянет на:
                                                      2,5 метра кода
                                                      При тех же 11pt.

                                                      Остальные примерно также или больше.
                                                      • 0
                                                        А теперь представьте у нас 10 картинок и в итоге это выльется в 30 метров кода и что это хранить вместе с нашим основным CSS кодом? Но, постойте CSS отвечает за стили и хранить в нем 30 метров абракадабр как то не правильно.

                                                        Конечно, можно выделить отдельный файл images.css, чтобы убрать всю эту «красоту» в отдельный файл, но тогда на чем мы выигрываем?
                                                        2 CSS файла VS 1 CSS и 1 спрайт.
                                                        • 0
                                                          Специально для этого есть решения, позволяющие упаковывать ваши картинки в цсс при деплое на прод. Не вижу в этом проблем.
                                                          • –2
                                                            В том то и проблема, что Вы не видите.

                                                            Сервисы по упаковке, хорошо, а если он недоступен?

                                                            PHP скрипт с регуляркой, а Вы учитвали, что при этом возрастет нагрузка на web-сервер?

                                                            Вы не провели достаточное исследование.
                                                            • +2
                                                              Я не использую сервисы, в моем случае (это рельсы), есть такой инструмент ка jammit github.com/documentcloud/jammit, который как раз пакует картинки в цсс, помимо множества других плюшек.

                                                              Возможно для php есть что-то подобное, не берусь утверждать…

                                                              • +2
                                                                И пакует он это все перед деплоем на прод.
                                                              • 0
                                                                Вы предлагаете упаковывать при каждом клиентсокм запросе?
                                                                • 0
                                                                  Нет, я предлагаю сделать настаящие исследование, чтобы действительно убедить людей использовать именно такой способ.
                                                                  • 0
                                                                    Какой же вы тупой.
                                                          • 0
                                                            Извините, я что-то не понял. Можете пояснить, где там 6 метров?
                                                            • –1
                                                              Перейдите по ссылке ниже!
                                                              • 0
                                                                Там одна страница текста. Где 6 метров?
                                                                • +1
                                                                  Ответ: 32 строки * 18 см = 576 см, что примерно 6 метров.
                                                                  • +1
                                                                    Очень неожиданно, если честно )

                                                                    Я просто не мог проверить до сего момента, то, что вы указывали в примерах и был крайне удивлен, результирующим кодом в 6 kb, а вы оказывается про длину говорили…
                                                                    • +1
                                                                      не kb, а mb — метрах, очепятка
                                                                    • +1
                                                                      Строчка в 18 см?!

                                                                      Надо было хотя бы раз вставить тег irony…
                                                                      • 0
                                                                        Неужели только мне нравится, когда код красивый (это ведь все таки стили)? И в нем нету сотен строк абракадабр?
                                                                        • +1
                                                                          Если оно делается в автомате при deploy, то кому какая разница?
                                                                      • 0
                                                                        А у нас тут ещё 31 марта…
                                                                        Спасибо, за поднятое настроение :)))
                                                          • 0
                                                            Вот посмотрите как будет выглядить код, для маленькой картинки:Посмотреть
                                                            • 0
                                                              А вот сама картинка:
                                                              image
                                                              • 0
                                                                Для цссок скорее подойдет большое количество маленьких изображений <= 1 kb, ну а потолок 32kb, поскольку восьмой ie их не переваривает.
                                                          • 0
                                                            в использовании dataURL есть минусы, один из них показан на этом видео video.yandex.ua/users/banzalik/view/5/#hq
                                                          • 0
                                                            Эффект как раз есть. И вполне материальный:
                                                            — увеличивается время загрузки страницы
                                                            — поступает команда: «Сделать быстрее, чтоб всё было ОК»
                                                            — картинки прячутся в CSS, а его, в свою очередь, забирает к себе CDN и отдаёт быстро-быстро много-много

                                                            Имеем — довольных посетителей, довольных заказчиков, премии и т.п. за один день работы
                                                            • +1
                                                              Если какой-нибудь портал при этом станет грузиться на 5-10 секунд быстрее, то это, конечно, круто, полезно и нужно:) А если речь идет о миллисекундах, то ситуация совсем уже другая.
                                                              • 0
                                                                У некоторых пользователей одно HTTP-соединение может открываться порядка секунды. При плохих пингах до пользователя, но вменяемых скоростях соединения профит от вписанных картинок очевиден.
                                                            • 0
                                                              Очень сложный вопрос. Дело в том, что Base64 код вполне может весить больше, чем картинка в web-форматах.
                                                              • +1
                                                                gzip нивелирует эту разницу
                                                                • –1
                                                                  Как показывает практика, PNG8 больше 30х30 чаще всего даже уменьшается в base64.
                                                                  • 0
                                                                    Это зависит от конкретной картинки!
                                                              • +1
                                                                Храните картинки на разных доменах и разных железках, это полезнее будет.
                                                                • 0
                                                                  Уменьшение http запросов это не только серверная оптимизация, это еще и клиентская. Даже, пожалуй, больше клиентская. Больше элементов на странице, больше запросов, больше памяти, больше файлов в кеше.
                                                                  А грамотно собранную статику можно держать на той же железке, что и фронтэнд.
                                                                • +2
                                                                  Не знаю в который раз уже пишут о Data Uri (очень много...), но можно же было хоть в ~ 100500-ый раз написать, что собирать изображение в строку нужно автоматически, а не руками. Следовательно проблем со сложностью обновления изображений быть не должно. Да и sprit'ы можно тоже в Data Uri засовывать…
                                                                  • 0
                                                                    Для ie7 можно использовать mhtml en.wikipedia.org/wiki/MHTML
                                                                  • 0
                                                                    Я правильно понимаю, что для 5-7 IE мы добавляем костыль в виде скрипта, и количество запросов становится тем же?)
                                                                    • –1
                                                                      Доля IE 5..7 стремительно падает, а восьмая версия уже поддерживает алгоритм base64. Для небольшого процента клиентов можно отдавать и другой CSS, где эти изображения отдаются статикой, что бы не пулять лишний раз запросы.
                                                                      • 0
                                                                        Для ie7 есть вполне «нормально» решение.
                                                                      • +1
                                                                        иногда уменьшение результативного объема изображения на больших файлах.

                                                                        Интересно как, если мне не изменяет память base64 увеличивает объем процентов на 30
                                                                        • +1
                                                                          Ага. Из каждых 3х байтов получаются 4.
                                                                          • 0
                                                                            В сыром http-запросе помимо всего прочего идет куча всякой фигни. За счет этого и получается экономия, но только для небольших файлов (навскидку, < 1 KiB).
                                                                          • +5
                                                                            Это обсуждалось столько раз и base64 и спрайты — и то и другое давно успешно применяется.
                                                                            Что нового Вы открыли миру хабру?
                                                                            • 0
                                                                              Автор ничего не открыл. И более того, не достаточно хорошо изучил вопрос. Изначально не привел никаких сведений о реальном изменении размера изображений до кодирования и после него, о замере времени реальной загрузки и т.д.
                                                                              • –1
                                                                                Топик постоянно обновляется, добавляется новый материал по теме из запросов читателей.
                                                                                • +1
                                                                                  Тогда удовлетворите наше любопытство и сделайте настоящее исследование расставив хоть какие-то точки над и. Например, вот так:
                                                                                  • Необходимо будет решить вопрос с размером картинок. Во первых изучить алгоритм Base64. Пережать, скажем сотню картинок. Выявить закономерности (Например, если в картинке есть градиент, то она скорее всего увеличится). Оформить графики. Сделать Выводы.
                                                                                  • Отобрать набор тестовых картинок (желательно разнотипных, типы должны появится из первого эксперемента). Загружать сайты с картинками с различных Web-серверов, машин, браузеров, в разное время суток в виде отдельных картинок, спрайтов, css. Оформить графики. Сделать Выводы.
                                                                                  • Изучить нагрузку на Web-сервер без перекодирования и с кодирование картинок в Base64. Сделать Выводы.
                                                                                  • Подвести общие итоги. Выписать плюсы и минусы. Дать конкретные рекомендации к каким картинкам и в каких случаях лучше применять этот метод, а в каких не стоит

                                                                                  Конечно, можно еще много чего добавить. Например, обзор сервисов (инструментов) для упоковки картинок в css.

                                                                                  Вот это было бы интересно.
                                                                                  • 0
                                                                                    Спасибо за ответ, внес в планы.
                                                                                    • 0
                                                                                      Base64 не занимается сжатием. Он просто перегруппировывает набор битов из групп по 8 в группы по 7 битов (очень упрощенно выражаясь), которые потом представляются в виде букв, цифр и пары спецсимволов. Таким образом, размера полученной последовательности можно прбилизительно оценить как originalSize*8/7.

                                                                                      Так что первые 2 пункта вроде как не нужны. Нагрузка на веб-сервер — это уже интереснее, хотя тут все-таки слишком много вариантов, но опять-таки все уже давно обсудили и даже тут на хабре =)
                                                                                  • +1
                                                                                    Реальная загрузка хороша видна невооруженным глазом на примере из комментов.

                                                                                    До оптимизации ~ 5 сек.
                                                                                    После оптимизации ~ 0.5 сек.
                                                                                    • +1
                                                                                      Вот реальные графики (Google Chrome, ~60 Мбит/сек):
                                                                                      До (102 запроса, 73,23 КБ передано, 3.41 сек):
                                                                                      image

                                                                                      После (2 запроса, 153,88 КБ передано, 0,94 сек):
                                                                                      image

                                                                                      Повторюсь: в современном интернете проще передать 1 файл в 1 МБ, чем 10 файлов по 100 КБ.

                                                                                      Так метровый файл начнет качаться, разгонится до предела и пойдет жара, а десятикилобайтные и разогнаться не успеют, да и времени на открытие соединения (пусть условно будет 1 секунда) будет тратится 1 секунда, против 10.

                                                                                      Ну и запросов к вебсерверву в 10 раз меньше, а это в 10 раз меньше строчек в лог файле.
                                                                                      • 0
                                                                                        Хорошо начало положено, только вот а где спрайты?
                                                                                        • 0
                                                                                          Все это должно быть в топике, а не в комментах. И блог выбрали правильно, так предшественников почитайте. И основоположника клиентской оптимизации на хабре sunnybear к примеру — его сайт www.webo.in
                                                                                          • 0
                                                                                            Да, только не в таком виде. На webo.in и небольшой видеокурс есть по клиентской оптимизации. Автору можно и его рекомендовать.
                                                                                  • 0
                                                                                    Для мобильных браузеров с отключенными картинками этот вариант плох: придется качать весь css файл
                                                                                    • –1
                                                                                      Для мобильных браузеров принято делать отдельный стиль или даже сайт.
                                                                                      • 0
                                                                                        Поговорим по этому поводу через пять лет, ок? Занесите в календарь напоминалку.
                                                                                        • 0
                                                                                          Еще год остался.
                                                                                          • 0
                                                                                            Полагаю, вопрос уже исчерпан. Даю новый прогноз. Еще пять лет и десктопы останутся только в памяти большой цивилизации. Интернет есть всё и интернет есть везде.
                                                                                            • 0
                                                                                              И на чём Вы будете кодить?
                                                                                      • 0
                                                                                        а так не приходится качать?
                                                                                      • 0
                                                                                        Сравниваю 2 диаграмы загрузки ресурсов и не могу понять, как на второй base64 изображения начали грузиться одновременно со страницей. И как вообще в таком случае определено понятие «загрузки» изображений, если они — часть css?
                                                                                        • –1
                                                                                          Это Chrome Developer Tools так отрисовывает графики, для движка HTML картинки как бы скачиваются, на самом деле они просто распаковываются, причем очень быстро. а главное — экономия http запросов.
                                                                                        • +1
                                                                                          Я вижу еще значительные недостатки, которые не указаны в статье:
                                                                                          1. Чтобы не потерять в удобстве расширения и изменения макета/стилей нужно писать некий скрипт, который бы парсил CSS-ы и подменял URI фоновых картинок на их base64 эквиваленты, а потом заменял подключение developer-friendly CSS-ов на сгенерированные.
                                                                                          2. Если одно изображение используется несколько раз возникает значительная избыточность.
                                                                                          3. Если рассматривать подход без использования base64, то сначала загружается HTML — рендерится разметка, следом CSS — применяются стили разметки (размеры, колонки, шрифты, бла-бла), а потом уже загружаются фоновые изображения, дополняя страницу деталями. В данном случае зачастую первых двух действий относительно достаточно для взаимодействия пользователя со страницей.
                                                                                          В случае с base64 значительно увеличивается размер CSS файла, замедляя загрузку стилей разметки, замедляя тем самым рендеринг макета и изменяя логичный (по моему мнению) ход вещей.
                                                                                          • –1
                                                                                            На современных скоростях интернет соединений гораздо быстрее скачать 1 файл в 1 024 байта, чем 10 файлов по 100 байт. Посмотрите в Developer Tools, сколько времени тратится на установку соединения с сервером.
                                                                                            • 0
                                                                                              Гораздо, это во сколько?
                                                                                              Вам же написали, логика немного страдает. Сначала разметка, затем стили. Все правильно и логично, достаточно для того, чтобы клацнуть по рубрикатору или «на главную». Затем картинки.
                                                                                              В случае картинок в css, стройная система слегка смещается.
                                                                                              Да и почему Вы почему так напуганы соединениями?
                                                                                              • 0
                                                                                                > Да и почему Вы почему так напуганы соединениями?

                                                                                                Соединение с сервером одна из самых затратных операций. Чем меньше соединений, тем быстрее грузится сайт. Да и на сервер нагрузка меньше.
                                                                                            • –1
                                                                                              А избыточность исправляется созданием отдельного стиля с изображением и подключением его к нескольким элементам.
                                                                                            • +1
                                                                                              А как отключить картинки? В смысле теперь при отключении картинок трафик не экономится.
                                                                                              • +2
                                                                                                Кстати, да, любопытный вопрос. Имею большой опыт сидения на дорогом жпрс-е.

                                                                                                Поразмышлял — выходит даже плюс. Ясно же, что в CSS имеет смысл засовывать мелкие картинки: значки, кнопки, пиктограммки, скругленные уголки и т.п. Они много не весят и вполне посильны даже для мобильной связи. И самое главное, зачастую без них макет выглядит неполноценно — непонятно куда можно кликать, теряются иконки статусов и т.д. (хотя отчасти это вопрос аккуратности разработчика). Зачастую хочется как раз эту копеечную мелочь врубить, оставив отключенными большие картинки основного контента.

                                                                                                Но дело в том, что если обычную картинку (тег IMG) можно легко посмотреть через команду контекстного меню, то изображение, подстеленное через css::background, отдельно просмотреть невозможно! Только включив вообще все картинки. Ну если не рассматривать варианты с файрбагом и копание в исходниках.
                                                                                              • +1
                                                                                                Давно пользуюсь data:url и могу сказать что все описанные недостатки нивелируются достоинствами этого метода оптимизации при его правильном использовании. Я имею в виду использование «быстрых» css селекторов, группировку селекторов при подключении одного изображения в разных местах, gzip сжатие. Время до показа страницы может немного и увеличивается, но незначительно и в большинстве случаев после этого человек получает уже практически полностью загруженную страницу и общее впечатление остается лучше чем когда страница грузится постепенно.

                                                                                                А на счет большого времени при изменении дизайна я категорически не соглашусь. Если сравнить время на изменения в дизайне при использовании data:url и его аналога css-спрайтов. То тут и обсуждать нечего data:url быстрее и удобнее. И это если еще не брать во внимание ограничения которые накладывает использование css-спрайтов. Я до сих пор с ужасом вспоминаю случаи когда заказчик просил внести большие изменения в спрайт из 40+ изображений.
                                                                                                • 0
                                                                                                  А как в случае с IE < 8 происходит работа? Там же ведь по сути не css, а значит надо будет писать еще один css, в котором картинки подключаются обычным образом. И кстати картинки, то в таком случае не станут дергаться с сервера?
                                                                                                • 0
                                                                                                  иногда уменьшение результативного объема изображения на больших файлах.
                                                                                                  это если изначально файл плохо сжат
                                                                                                  подозреваю, они заодно оптимизируют
                                                                                                  а так нет, этого не может быть, потому что не может быть никогда
                                                                                                  • 0
                                                                                                    До / после
                                                                                                    Увеличил объём данных в 2 раза, зато уменьшили число запросов в 50 раз.
                                                                                                    Понятно, что станет лучше.

                                                                                                    Вообще, у меня есть идея как оценивать такие штуки чисто теоретически.
                                                                                                    Смотрим цены на запросы и трафик, например, на Amazon S3 и считаем, что выгодней по деньгам. Где по деньгам выгодней — там и нагрузка будет меньше, скорей всего.
                                                                                                    • –1
                                                                                                      Не все нужно совать в data:uri, туда только то, что действительно необходимо (реально маленькие файлы), если есть вариант использовать CSS спрайты — лучше юзать их, потому что data:image из base64 распаковывается дольше, чем простая картинка, но грузится быстрее.
                                                                                                      • 0
                                                                                                        Я и не говорил, что всё. Но с такими соотношениями для 99% сайтов data/uri будет точно выгодней. Хотя совсем не исключено, что спрайты будут еще выгодней.
                                                                                                    • 0
                                                                                                      > Кодируем изображение в base64 с помощью онлайн сервисов

                                                                                                      Вот этого не надо IMHO советовать. Мало ли какой эксплойт они там подсунут/подмешают.

                                                                                                      Лучше добавьте ссылку на удобный инструмент, которым легко пользоваться у себя.
                                                                                                      • 0
                                                                                                        Только для автоматической, так называемой, компиляции css, исходники имхо должны оставаться поддерживаемыми
                                                                                                        • 0
                                                                                                          Вот нашел несколько интересных статей.

                                                                                                          Про скорость рендеринга таких картинок: data:URI и производительность, или как замедлить Firefox в 10 (десять) раз
                                                                                                          И еще вот: Кроссбраузерное использование data:URL
                                                                                                          • 0
                                                                                                            Спасибо, у меня в текущем проекте как раз много мелких иконок.
                                                                                                            Написал себе python-скрипт для конвертации url("../path") в url(data:image/png;base64, data)
                                                                                                          • 0
                                                                                                            а что значит «картинки нельзя засунуть в спрайты»?
                                                                                                            • 0
                                                                                                              OK, а как тогда определённый слой SVG таким образом использовать?
                                                                                                              Допустим, мы упаковали SVG в base64, прописали правильный mime (image/svg+xml), а как слой тогда указать (было, например, filters.svg#superslice).
                                                                                                              • 0
                                                                                                                Вот монстры интернета, например, Google и Apple на своих сайтах используют спрайты. Думаю лучше использовать именно их. Еще и редактировать удобно (в какой-то мере) — открыл один файл и правишь львиную часть дизайна. Удобно.
                                                                                                                • 0
                                                                                                                  Круть — анимированный гиф тоже поддерживается севрисом www.dailycoding.com/Utils/Converter/ImageToBase64.aspx
                                                                                                                  • 0
                                                                                                                    Emmet, который есть почти для всех популярных редакторов, кроме чудесного Zen coding в том числе умеет по шорткату конвертировать изображения в base64. В Coda 2 — курсор в любое место URL с изображением, Ctrl+I и готово.

                                                                                                                    Только полноправные пользователи могут оставлять комментарии. Войдите, пожалуйста.