Я создаю веб-сайт, и я хочу сделать HTTP-запросы как можно меньше для лучшей скорости сайта и SEO. Страница, которую я только что создал, показывает изображения при прокрутке (изображения имеют атрибут data-scr, который преобразуется в src, когда пользователь прокручивает вниз на соответствующем изображении).
Поскольку все изображения имеют data-src
атрибут вместо src
, W3C показывает мне ошибки.
На данный момент я нашел два варианта, чтобы решить эту проблему:
- Исходный источник всех изображений должен быть URL пустого изображения 1x1
- Исходный источник всех изображений должен быть базой данных 64 пустое изображение
Когда я использую URL пустого изображения 1x1, тогда (протестировано с tools.pingdom.com) он показывает 1 HTTP-запрос. Когда я использую пустое изображение из базы данных 64, тогда оно показывает столько же запросов, сколько количество изображений на странице.
Какой из них является более эффективным, поскольку веб-сайт работает быстрее и делает меньше HTTP-запросов? (предположим, что пользователь загружает веб-страницу со скоростью интернета 14,4 кбит / с - первая скорость интернета).
Но для SEO?
Есть ли другой вариант?
источник
Ответы:
Опцию base64 image следует использовать там, где у вас будет только очень небольшое количество изображений, и вы хотите устранить сетевые накладные расходы при получении изображения с сервера. Однако из того, что вы указываете в вопросе, я предполагаю, что это может масштабироваться до большого количества изображений. В этом случае я бы использовал одно прозрачное изображение размером 1px x 1px с сервера с большим временем жизни кеша, так как оно будет выбрано с сервера, а затем кэшировано в браузере и любых промежуточных прокси-серверах.
Например, размер этого изображения будет около 95 байт ( https://commons.wikimedia.org/wiki/File:1x1.png ), для строки изображения в кодировке base64 вы обнаружите, что размер будет на уровне этого изображения размер файла, но будет повторяться для каждого изображения, к которому вы добавляете его.
Для 2-5 изображений размер и скорость будут незначительными и уменьшат трафик сервера, исключив одну целую выборку, но, более того, размер страницы станет слишком большим, что повлияет на время загрузки и, в свою очередь, на рейтинг SEO.
источник

. Если URL-адрес изображения немного длиннее (например, example.com/templates/template-name/files/1x1.png ), будет рекомендовано изображение base64, поскольку вы не выполняете HTTP-запросы и оно меньше в байтах чем URL изображения (повторяется для каждого изображения на странице) + размер внешнего изображения.Обязательно используйте URI данных, если вам не нужна поддержка IE <8. ( Поддержка браузера .)
Встраивание множества крошечных изображений непосредственно в HTML может выглядеть так, как если бы оно занимало большую полосу пропускания, чем прямая ссылка на них, но увеличение будет уменьшено с помощью gzip ; единственная разница в размере страницы будет заключаться в разнице в длине между одним URI данных пустого изображения и одним URL-адресом изображения на вашем сервере. Пустой GIF может быть как 43 байт. База 64-кодирована, это 82 байта. Нет способа, который когда-либо будет работать хуже, чем HTTP-запрос> 500 байт, ответ такого же размера, и тогда я даже не принимаю во внимание размер пакета TCP и другие издержки.
Вот базовое 64-байтовое 43-байтовое GIF-изображение:
Что касается SEO, взгляните на исходный код сайта Google, например, Новости Google , и выполните поиск
data:image/gif,base64
…источник
Эта опция не только требует современного браузера, но она может быть медленнее на стороне клиента, так как браузер должен base-64 декодировать данные изображения, чтобы получить изображение.
Это нормально, при условии, что пустой URL-адрес изображения для всех слотов изображений является точно таким же URL-адресом и что он имеет длительное время жизни кэша, определенное в заголовке HTTP «cache-control». Проблема заключается в том, что при загрузке новых файлов изображений квадраты изображений переходят к новому размеру, что может сделать работу пользователя не такой замечательной.
Почти идеальная идея заключается в следующем ...
Когда страница запускается, представьте сетку с полями фиксированного размера, которые могут вместить каждое изображение. Это нормально, если вся сетка не помещается на экране. Затем создайте javascript, который выполняется после загрузки HTML, и в этом javascript создайте новый элемент изображения и прикрепите его к каждой ячейке сетки, затем установите источник изображения в правильный файл изображения. Делайте это, пока не заполнится первый экран. затем обнаружите прокрутку в javascript, а затем, когда прокрутка произойдет, повторите описанный выше процесс для новых ячеек.
Теперь, если вы хотите получить лучшее из лучшего, а качество не имеет большого значения, то я рекомендую (я также реализовал это на своем сайте) построить сетку и настроить ее так, чтобы фоновое изображение этой сетки было спрайт-лист всех изображений, отформатированных как квадраты изображений. Этот метод является гибким и быстрым для загрузки, так как для всех изображений требуется один запрос.
Вот шаблон HTML для использования, если вы хотите идти быстрым путем. Только два запроса сделаны. HTML-код и одно изображение. В этом коде я предполагаю, что каждое изображение с листа имеет ширину 100 пикселей и высоту 200 пикселей и что каждое изображение идеально выровнено рядом друг с другом без пропусков.
В своем коде я добавил 3 точки. Это означает, что вы можете продолжать добавлять изображения, увеличивая числа и увеличивая положение на 100 каждый раз, если ваш спрайт-лист содержит только одну строку изображений. Кроме того, в некоторых браузерах, таких как Opera, вам может понадобиться добавить знак минуса перед значениями положения фона, чтобы заставить их работать.
источник
Изображение, потому что ремонтопригодность.
По моему опыту, лучше использовать изображение. Это более очевидно в реальном коде и легче запомнить. Я сомневаюсь, что вы помните закодированную строку для прозрачного изображения, и даже если вы это сделаете, ваши преемники / коллеги.
Если вы вернетесь к этому коду через несколько недель, вы забудете base64.
Поддерживать код будет намного проще, если вы используете изображение, минимальный профессионал не справится с этим.
источник
Как насчет всего ~ 3 дополнительных байта, 0 дополнительных запросов http и 0 дополнительных длин img src (или 0 не кешированных заполнителей для данных данных). Можете ли вы использовать пустой SRC для изображения?
<img src data-src="banannanannas.jpg" />
И если у них есть
alt
теги, вы можете скрыть их от изображения ошибки / сбоя:<img src data-src="banannanannas.jpg" onerror="this.alt=''" alt="some desc" />
Отображает: ничего. Взлом метки alt имеет небольшую задержку FOUC от границы заполнителя изображения. Возможно, это тоже можно убрать.
источник
src
атрибут все равно выдаст ошибки в W3C Validator (что, похоже, является проблемой).