Prefetch
Page load times play a big role in the usability and overall enjoyment of a site. Astro’s opt-in prefetching brings the benefits of near-instant page navigations to your multi-page application (MPA) as your visitors interact with the site.
Enable prefetching
Section titled Enable prefetchingYou can enable prefetching with the prefetch
config:
A prefetch script will be added to all pages of your site. You can then add the data-astro-prefetch
attribute to any <a />
links on your site to opt-in to prefetching. When you hover over the link, the script will fetch the page in the background.
Note that prefetching only works for links within your site, and not external links.
Prefetch configuration
Section titled Prefetch configurationThe prefetch
config also accepts an option object to further customize prefetching.
Prefetch strategies
Section titled Prefetch strategiesAstro supports 3 prefetch strategies for various use cases:
hover
(default): Prefetch when you hover over or focus on the link.tap
: Prefetch just before you click on the link.viewport
: Prefetch as the links enter the viewport.
You can specify a strategy for an individual link by passing it to the data-astro-prefetch
attribute:
Each strategy is fine-tuned to only prefetch when needed and save your users’ bandwidth. For example:
- If a visitor is using data saver mode or has a slow connection, prefetch will fallback to the
tap
strategy. - Quickly hovering or scrolling over links will not prefetch them.
- Links that use the
viewport
strategy are prefetched with a lower priority to avoid clogging up the network.
Default prefetch strategy
Section titled Default prefetch strategyThe default prefetch strategy when adding the data-astro-prefetch
attribute is hover
. To change it, you can configure prefetch.defaultStrategy
in your astro.config.js
file:
Prefetch all links by default
Section titled Prefetch all links by defaultIf you want to prefetch all links, including those without the data-astro-prefetch
attribute, you can set prefetch.prefetchAll
to true
:
You can then opt-out of prefetching for individual links by setting data-astro-prefetch="false"
:
The default prefetch strategy for all links can be changed with prefetch.defaultStrategy
as shown in the Default prefetch strategy section.
Prefetch programmatically
Section titled Prefetch programmaticallyAs some navigation might not always appear as <a />
links, you can also prefetch programmatically with the prefetch()
API from the astro:prefetch
module:
You can additionally configure the priority of prefetching by passing the with
option:
The prefetch()
API includes the same data saver mode and slow connection detection, so that it only prefetches when needed.
To ignore slow connection detection, you can use the ignoreSlowConnection
option:
Make sure to only import prefetch()
in client-side scripts as it relies on browser APIs.
Using with View Transitions
Section titled Using with View TransitionsWhen you use View Transitions on a page, prefetching will also be enabled by default. It sets a default configuration of { prefetchAll: true }
which enables prefetching for all links on the page.
You can customize the prefetch configuration in astro.config.js
to override the default. For example:
Migrating from @astrojs/prefetch
Section titled Migrating from @astrojs/prefetchThe @astrojs/prefetch
integration was deprecated in v3.5.0 and will eventually be removed entirely. Use the following instructions to migrate to Astro’s built-in prefetching which replaces this integration.
-
Remove the
@astrojs/prefetch
integration and enable theprefetch
config inastro.config.js
: -
Convert from
@astrojs/prefetch
’s configuration options:-
The deprecated integration used the
selector
config option to specify which links should be prefetched upon entering the viewport.Add
data-astro-prefetch="viewport"
to these individual links instead. -
The deprecated integration used the
intentSelector
config option to specify which links should be prefetched when they were hovered over or focused.Add
data-astro-prefetch
ordata-astro-prefetch="hover"
to these individual links instead: -
The
throttles
option from@astrojs/prefetch
is no longer needed as the new prefetch feature will automatically schedule and prefetch optimally.
-