Помогите браузеру с помощью подсказок по ресурсам

В последнем модуле об оптимизации загрузки ресурсов вы узнали, как различные ресурсы страницы, такие как CSS и JavaScript, могут влиять на скорость загрузки страницы и как можно оптимизировать их и их доставку, чтобы ускорить отрисовку страницы. Это идеальное время для перехода к более сложному аспекту загрузки ресурсов, который включает в себя помощь браузеру загружать их быстрее с помощью подсказок по ресурсам.

Подсказки по ресурсам могут помочь разработчикам оптимизировать время загрузки страницы, сообщая браузеру, как загружать ресурсы и расставлять приоритеты. Первым был представлен первоначальный набор подсказок по ресурсам, таких как preconnect и dns-prefetch . Однако со временем preload и Fetch Priority API предоставили дополнительные возможности.

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

Подсказки по ресурсам могут быть указаны в HTML — чаще всего в начале элемента <head> — или установлены в виде заголовка HTTP . В рамках этого модуля рассматриваются preconnect , dns-prefetch и preload , а также спекулятивное поведение выборки, которое обеспечивает prefetch .

preconnect

Подсказка preconnect используется для установления соединения с другим источником, откуда вы извлекаете важные ресурсы. Например, вы можете размещать свои изображения или ресурсы на CDN или другом перекрестном источнике:

<link rel="preconnect" href="https://example.com">

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

Если на странице имеется большое количество ресурсов из разных источников, используйте preconnect для тех ресурсов, которые наиболее важны для текущей страницы.

Скриншот времени подключения ресурса на сетевой панели Chrome DevTools. Настройка соединения включает время задержки, согласование прокси-сервера, поиск DNS, настройку соединения и согласование TLS.
Визуализация времени подключения на сетевой панели Chrome DevTools. Время в красном поле — это время, необходимое для установки соединения с сервером с перекрестным происхождением, которое можно уменьшить при preconnect , установив соединения раньше, а не во время обнаружения ресурса с перекрестным происхождением.

Распространенным вариантом использования preconnect является Google Fonts . Google Fonts рекомендует preconnect к домену https://fonts.googleapis.com , который обслуживает объявления @font-face , и к домену https://fonts.gstatic.com , который обслуживает файлы шрифтов.

<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>

Атрибут crossorigin используется, чтобы указать, должен ли ресурс быть получен с использованием совместного использования ресурсов Cross-Origin (CORS) . Если при использовании подсказки preconnect ресурс, загружаемый из источника, использует CORS (например, файлы шрифтов), вам необходимо добавить атрибут crossorigin в подсказку preconnect .

dns-prefetch

Хотя раннее открытие подключений к серверам с несколькими источниками может значительно сократить время начальной загрузки страницы, устанавливать соединения со многими серверами с несколькими источниками одновременно может оказаться неразумным или невозможным. Если вы обеспокоены тем, что можете злоупотреблять preconnect , гораздо менее затратным ресурсом является подсказка dns-prefetch .

Судя по названию, dns-prefetch не устанавливает соединение с перекрестным сервером, а просто заранее выполняет для него поиск DNS . Поиск DNS происходит, когда имя домена преобразуется в его базовый IP-адрес. Хотя уровни кэшей DNS на уровне устройства и сети помогают сделать этот процесс в целом быстрым, он все равно занимает некоторое время.

<link rel="dns-prefetch" href="https://fonts.googleapis.com">
<link rel="dns-prefetch" href="https://fonts.gstatic.com">

Поиск DNS довольно недорог, и из-за его относительно небольшой стоимости в некоторых случаях он может быть более подходящим инструментом, чем preconnect . В частности, это может быть желательной подсказкой к ресурсу, которую следует использовать в случаях, когда ссылки ведут на другие веб-сайты, на которые, по вашему мнению, пользователь может перейти. dnstradamus — один из таких инструментов, который делает это автоматически с помощью JavaScript и использует API Intersection Observer для внедрения подсказок dns-prefetch в HTML текущей страницы, когда ссылки на другие веб-сайты прокручиваются в область просмотра пользователя.

preload

Директива preload используется для инициирования раннего запроса ресурса, необходимого для рендеринга страницы:

<link rel="preload" href="/lcp-image.jpg" as="image">

Директивы preload должны быть ограничены поздно обнаруженными критическими ресурсами. Наиболее распространенными вариантами использования являются файлы шрифтов, файлы CSS, полученные с помощью объявлений @import , или ресурсы background-image CSS, которые, вероятно, будут кандидатами на наибольшую контентную отрисовку (LCP) . В таких случаях эти файлы не будут обнаружены сканером предварительной загрузки, поскольку на ресурс есть ссылка во внешних ресурсах.

Как и в случае с preconnect , директиве preload требуется атрибут crossorigin , если вы предварительно загружаете ресурс CORS, например шрифты. Если вы не добавите атрибут crossorigin (или не добавите его для запросов, отличных от CORS), тогда ресурс будет загружен браузером дважды , тратя впустую полосу пропускания, которую можно было бы лучше потратить на другие ресурсы.

<link rel="preload" href="/font.woff2" as="font" crossorigin>

В предыдущем фрагменте HTML браузеру предлагается предварительно загрузить /font.woff2 с помощью запроса CORS, даже если /font.woff2 находится в том же домене.

prefetch

Директива prefetch используется для инициирования запроса с низким приоритетом для ресурса, который, вероятно, будет использоваться для будущей навигации:

<link rel="prefetch" href="/next-page.css" as="style">

Эта директива в основном соответствует тому же формату, что и директива preload , только вместо атрибута rel элемента <link> используется значение "prefetch" . Однако, в отличие от директивы preload , prefetch в значительной степени является спекулятивной, поскольку вы инициируете выборку ресурса для будущей навигации, которая может произойти, а может и не произойти.

Бывают случаи, когда prefetch может быть полезной — например, если вы определили поток пользователей на своем веб-сайте, которому большинство пользователей следуют до завершения, prefetch критически важного для рендеринга ресурса для этих будущих страниц может помочь сократить время их загрузки. .

API приоритета получения

Вы можете использовать Fetch Priority API через его атрибут fetchpriority , чтобы повысить приоритет ресурса. Вы можете использовать атрибут с элементами <link> , <img> и <script> .

<div class="gallery">
  <div class="poster">
    <img src="img/poster-1.jpg" fetchpriority="high">
  </div>
  <div class="thumbnails">
    <img src="img/thumbnail-2.jpg" fetchpriority="low">
    <img src="img/thumbnail-3.jpg" fetchpriority="low">
    <img src="img/thumbnail-4.jpg" fetchpriority="low">
  </div>
</div>

По умолчанию изображения загружаются с более низким приоритетом. Если после компоновки обнаруживается, что изображение находится в пределах начальной области просмотра, приоритет увеличивается до «Высокий ». В предыдущем фрагменте HTML fetchpriority немедленно сообщает браузеру загрузить большее изображение LCP с высоким приоритетом, в то время как менее важные миниатюры изображений загружаются с более низким приоритетом.

Современные браузеры загружают ресурсы в два этапа. Первый этап зарезервирован для критически важных ресурсов и заканчивается после загрузки и выполнения всех блокирующих сценариев. На этом этапе загрузка ресурсов с низким приоритетом может задерживаться. Используя fetchpriority="high" вы можете повысить приоритет ресурса, позволяя браузеру загрузить его на первом этапе.

Демо-подсказки по ресурсам

Проверьте свои знания

Что делает подсказка ресурса preconnect ?

Открывает соединение с перекрестным сервером, включая поиск DNS, а также соединение и согласование TLS до того, как браузер в противном случае обнаружит его.
Правильный!
Выполняет только поиск DNS для сервера перекрестного происхождения.
Попробуйте еще раз.

Что позволяет API Fetch Priority?

Укажите приоритет загрузки HTML-кода текущей страницы.
Попробуйте еще раз.
Укажите относительный приоритет для элементов <link> , <img> и <script> .
Правильный!

Когда следует использовать подсказку prefetch ?

Для любых ресурсов или страниц, которые могут понадобиться пользователю, независимо от того, понадобятся ли они ему в будущем.
Попробуйте еще раз.
Когда у вас есть высокая уверенность в том, что ресурсы или страницы, которые вы собираетесь предварительно загрузить, нужны пользователю.
Правильный!
Если пользователь не выразил явного предпочтения по сокращению использования данных.
Правильный!

Далее: производительность изображения

К этому моменту вы, вероятно, начинаете чувствовать себя довольно уверенно в своих знаниях общих вопросов производительности, когда дело касается HTML-страницы, элемента <head> и подсказок по ресурсам. Однако существуют дополнительные оптимизации, специфичные для различных типов ресурсов, которые обычно загружаются страницами. Далее, производительность изображений рассматривается в следующем модуле, который поможет вам обеспечить максимально быструю загрузку изображений вашего веб-сайта, независимо от устройства пользователя.