Below is a list of optimizations you can implement to improve the performance of your website. This list is not exhaustive and needs (continual) updating.
-
<link rel="preload">
-- add thepreload
value to yourlink
elements to tell the browser to start fetching this resource earlier in the lifecycle of a page load. This will ensure that the resource is less likely to block the page's first render. Sources: Blog post, MDN, Examples-
as
property -- (example:<link="preload" href="something.js" as="script"
); usingas
allows the browser to prioritize the resource loading more accurately (i.e. when used with fonts, it will change it to High priority) -
<link rel="prefetch">
-- differs frompreload
in that it tells the browser to fetch a resource that will probably be needed for next navigation. This means the resource will be fetched with extremely low priority because the main use case ofprefetch
is to speed up the next page's navigation. -
<link rel="subresource">
-- intended to work likeprefetch
in Chrome but doesn't support priority loading so all resources downloaded at fairly low priority
-
-
HTTP2 (H2 Server Push) -- the idea that we can avoid requesting a resource and instead push a resource from the server, since the server knows the browser will need them. When the client finally needs the resource, it's already there waiting. When used with service workers, this will cut out one full round trip to your server! Sources: Chrome Dev Summit 2016
-
Caveat: not cache aware -- the server doesn't have an idea about the state of your client, it will push the asset regardless of your browser's cache.
-
Caveat: lacks resource prioritization -- the browser knows which resources are critical, and which can be deferred. H2SP does not have this optimization built in.
-
Caveats Solved -- use service workers! With SW, the browser doesn't hit the server, the assets are served from the SW. This avoids opening a connection to your server. Because you did not open a connection, the server cannot push you resources you don't need.
-
-
Progressive Web App (PWA) -- using Google Chrome Lighthouse, you should try to achieve a score of 100. Read more
-
Tree shaking
-
Minification
-
Ahead-of-time compilation (Angular)
-
Code splitting
-
Asset Caching
-
Bundle JS
-
lazy loading
-
Google Lighthouse (add to CLI & dev workflow)
-
Script tags
- defer & async
- add to bottom of body
-
Server side rendering (SSR)
-
Accelerated Mobile Pages (AMP)
-
Put critical CSS in head and others in body