Load low priority, non-critical CSS resources in the background without impacting page speed with this simple technique for asynchronous CSS loading.Jump To The Result
What Is Asynchronous Loading?
Asynchronous or async loading refers to downloading and applying a page resource in the background, independently of other resources and without otherwise impacting the initial loading process.
This configuration is ideal for CSS that doesn't apply to initially-visible or above-the-fold content elements and can be added to the page later in the loading process. Also called non-critical CSS, loading low priority CSS files asynchronously is a common technique to eliminate render blocking CSS and improve website speed.
The terms lazy loading, on-demand, deferred, and asynchronous are all related to the various methods for minimizing initial-load page weight and eliminating render blocking resources. Although often used semi-interchangeably, there are some key differences.
Lazy Loaded = Loaded preemptively in anticipation of a need.
For example, as the page is scrolled or when a particular content element is revealed. Lazy loading images is the most common use, but it can also be effective for other resources like CAPTCHA plugins used toward the bottom of the page.
On-Demand = Loaded only when needed.
Similar to lazy loading, but typically in response to a more specific, purposeful action like loading a video when the play button is clicked or loading CAPTCHA resources when a user starts interacting with a form.
Deferred = Loaded or applied later in the initial loading process.
As with deferring Google Analytics, the
deferattribute can be added to external
<script>references to both load in the background and execute after initial rendering of the page, right before the
Asynchronous = Loaded or applied independently of other resources.
Asynchronous loading is a good choice for files that are part of general page loading, but shouldn't interfere with higher priority resources in the loading process.
Reconfiguring CSS For Speed
External CSS resources are included on the page with a
<link> reference to the file:
A conventional, render blocking reference like this to a very small CSS file (<10KB minified & compressed) is appropriate for critical styles that apply to the initially-visible or above-the-fold parts of the page so that users don't see a flash of unstyled content. However for non-critical CSS that only applies to below-the-fold content, the render blocking effect negatively impacts page speed.
Optimize the loading process with a progressive approach.
Enter Asynchronous CSS
Rather than interrupting the loading process with a conventional, render blocking CSS reference, asynchronous CSS loads in the background. The HTML can continue to be analyzed by the browser, other more important resources can continue to load and the page can be rendered and appear on screen as quickly as possibly.
Asynchronous CSS uses a simple combination of the
(This is the core functionality of asynchronous CSS - jump down for the complete solution.)
Breaking It Down
This technique benefits from the fact that browsers still download file references with non-matching media conditions, but do so in the background at a low priority without blocking page rendering.
- As with any other
<link>reference the browser encounters, the file starts downloading, but because the
mediaattribute doesn't match the current conditions the file isn't render blocking.
- Once the file is loaded, the
mediaattribute to a matching value - or by removing it completely, as above with
this.removeAttribute('media');- so that the
<link>and the non-critical CSS now applies to the page.
this.onload=null; avoids calling
onload again in some browsers.)
media attribute technique is seen with a value like "none", which isn't valid HTML. (And who needs that?) A value like
(max-width:1px) or similar won't match any user screen conditions while remaining valid code.
<link> reference wrapped in a
<noscript> is an easy fallback:
Increase Loading Priority
For otherwise well-optimized pages without many other competing resources, the priority of asynchronously-loaded CSS can be optionally increased by adding a
preload resource hint:
Note the added
as attribute. Learn all about resource hints and which attributes are required and which are optional.
Why not simplify and combine the async
<link> reference with
Unfortunately browser support for the
Along with separating critical from non-critical CSS, another beneficial strategy to eliminate render blocking CSS is to organize CSS files by media conditions.
Media queries can selectively prioritize critical resources based on conditions like screen size. All files will be downloaded, but with appropriate priority, and only files with matching media conditions will block rendering.
Placing non-critical CSS references at the end of the page, before the closing
</body> tag has a similar effect:
Depending on the quantity and complexity of the page content and other resources, the downside of this method is that files may not begin loading as soon as files referenced in the
<head> section, increasing the potential for a flash of unstyled content.
Putting all of these elements together yields a simple and effective method for asynchronous CSS loading and faster page speed:
Async CSS For Google Fonts
Along with improving the loading efficiency of general CSS resources, asynchronous loading is a great technique to eliminate the render blocking effect of Google Fonts.Optimize Google Fonts