Learn about rel=preconnect and rel=dns-prefetch resource hints and how to use them.
Before the browser can request a resource from a server, it must establish a connection. Establishing a secure connection involves three steps:
In each of these steps the browser sends a piece of data to a server, and the server sends back a response. That journey, from origin to destination and back, is called a round trip.
Depending on network conditions, a single round trip might take a significant amount of time. The connection setup process might involve up to three round trips—and more in unoptimized cases.
Taking care of all that ahead of time makes applications feel much faster. This post explains how to achieve that with two resource hints:
<link rel=preconnect> and
Modern browsers try their best to anticipate what connections a page will need, but they cannot reliably predict them all. The good news is that you can give them a (resource 😉) hint.
rel=preconnect to a
<link> informs the browser that your page intends to establish a connection to another domain, and that you'd like the process to start as soon as possible. Resources will load more quickly because the setup process has already been completed by the time the browser requests them.
Resource hints get their name because they are not mandatory instructions. They provide the information about what you'd like to happen, but it's ultimately up to the browser to decide whether to execute them. Setting up and keeping a connection open is a lot of work, so the browser might choose to ignore resource hints or execute them partially depending on the situation.
Informing the browser of your intention is as simple as adding a
<link> tag to your page:
<link rel="preconnect" href="https://example.com">
You can speed up the load time by 100–500 ms by establishing early connections to important third-party origins. These numbers might seem small, but they make a difference in how users perceive web page performance.
chrome.com improved Time To Interactive by almost 1 s by pre-connecting to important origins.
Due to versioned dependencies, you sometimes end up in a situation where you know you'll be requesting a resource from a particular CDN, but not the exact path for it.
An example of a versioned URL.
The other common case is loading images from an image CDN, where the exact path for an image depends on media queries or runtime feature checks on the user's browser.
An example of an image CDN URL.
In these situations, if the resource you'll be fetching is important, you want to save as much time as possible by pre-connecting to the server. The browser won't download the file until your page requests it, but at least it can handle the connection aspects ahead of time, saving the user from waiting for several round trips.
Another example where you may want to save some time in the connection phase, but not necessarily start retrieving content right away, is when streaming media from a different origin.
Depending on how your page handles the streamed content, you may want to wait until your scripts have loaded and are ready to process the stream. Pre-connecting helps you cut the waiting time to a single round trip once you're ready to start fetching.
One way of initiating a
preconnect is adding a
<link> tag to the
<head> of the document.
<head> <link rel="preconnect" href="https://example.com"> </head>
Pre-connecting is only effective for domains other than the origin domain, so you shouldn't use it for your site.
Caution: Only pre-connect to critical origins you will use soon. If the connection isn't used within 10 seconds, the browser closes it. There's a limit to the number of simultaneous connections a browser can handle. (For example, Chrome can handle six.) Unnecessary pre-connecting can delay other important resources.
Link: <https://example.com/>; rel=preconnect
A benefit of specifying a preconnect hint in the HTTP header is that it doesn't rely on markup being parsed, and it can be triggered by requests for stylesheets, scripts, and more. For example, Google Fonts sends a
Link header in the stylesheet response to pre-connect to the domain that hosts the font files.
Some types of resources, such as fonts, are loaded in anonymous mode. For those you must set the
crossorigin attribute with the
<link rel="preconnect" href="https://example.com/ComicSans" crossorigin>
If you omit the
crossorigin attribute, the browser only performs the DNS lookup.
You remember sites by their names, but servers remember them by IP addresses. This is why the domain name system (DNS) exists. The browser uses DNS to convert the site name to an IP address. This process — domain name resolution— is the first step in establishing a connection.
Because there's a limit to the number of connections a browser can open, you sometimes can't pre-connect to all your important domains. In that case use
<link rel=dns-prefetch> to save time on the first step—the DNS lookup, which usually takes around 20–120 ms.
DNS resolution is initiated similarly to
preconnect: by adding a
<link> tag to the
<head> of the document.
<link rel="dns-prefetch" href="http://example.com">
<link rel="preconnect" href="http://example.com"> <link rel="dns-prefetch" href="http://example.com">
Recommended — To safely implement the fallback technique use separate link tags.
<link rel="preconnect dns-prefetch" href="http://example.com">
Not recommended — Implementing
dns-prefetch fallback in the same
<link> tag causes a bug in Safari where
preconnect gets cancelled.
preconnect only for the most important resources, rely on
dns-prefetch for the rest, and always measure the impact in the real-world.
Thanks for reading ❤
If you liked this post, share it with all of your programming buddies!
Looking for an attractive & user-friendly web developer? HourlyDeveloper.io, a leading web, and mobile app development company, offers web developers for hire through flexible engagement models. You can **[Hire Web...
Do you want excellent and world class web development services for your valuable projects? Contact **RB Genie **now, we have more than 8 years experienced team of web developers, which specializes in overall web design and website development...
With the rapid development in technology, the old ways to do business have changed completely. A lot more advanced and developed ways are ...
You name the business and I will tell you how web development can help you promote your business. If it is a startup or you seeking some...
We provide top-notch ReactJS development services to global clients. Hire expert ReactJS developers from top React JS development company, Skenix Infotech.