Пустое изображение, закодированное как данные-uri [дубликат]


этот вопрос уже есть ответ здесь:

Я построил слайдер изображения (на основе потрясающего bxSlider) который будет предварительно загружать изображения как раз вовремя, прежде чем они скользят в поле зрения. Это уже работает довольно хорошо, но я не думаю, что мое решение является допустимым HTML.

моя техника заключается в следующем: Я создаю разметку слайдера с первым изображением слайда, вставленным как обычно (с <img src="foo.jpg">) и последующие изображения, на которые ссылаются в атрибуте данных, например <img data-orig="bar.jpg">. Затем Javascript жонглирует data-orig -> src измените при необходимости, вызывая предварительную загрузку.

другими словами, у меня есть:

<div class="slider">
    <div><img src="time.jpg" /></div> 
    <div><img src="data:" data-orig="fastelavn.jpg" /></div> 
    <div><img src="data:" data-orig="pels_strik.jpg" /></div> 
    <div><img src="data:" data-orig="fashion.jpg" /></div> 
</div>

С src="" атрибуты (такие как вредно для производительность на некоторые браузеры), я вставил src="data:" эффективно вставить пустое изображение в качестве заполнителя.

дело в том, что я ничего не могу найти в документация для data-URI говоря, является ли это допустимым data-URI или нет. Я в основном хочу минимальный URI данных, который разрешает пустое / прозрачное изображение, поэтому браузер может немедленно разрешить src и двигаться дальше (без ошибки или сетевого запроса). Может быть src="data:image/gif;base64," будет лучше?

7 63

7 ответов:

Я посмотрел в него и наименьшее возможное прозрачное изображение GIF, закодированный как data-uri, был такой:



что я использую сейчас.

если вам нужно прозрачное изображение 1x1 пиксель просто установите эти данные uri как src по умолчанию



это вместо кодировки base64 для изображения 1x1 белый



в противном случае вы можете установить data:null и сохранить ~60 дополнительных байт для каждого изображения

data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg"/>

действительный и сильно сжимаемый. По существу бесплатно, если на странице есть еще один встроенный svg.

самый маленький, который я когда-либо видел

данные: изображение / gif; base64, R0lGODlhAQABAAAAACw=



меньше :D

1px на 1px JPEG image



"белый gif" Фабрицио на самом деле не совсем белый : это rgb(254, 255, 255).

Я использую следующий (который оказывается меньше), найденный на на этой странице.

