Preload plugin
Adds preloading support to swup:
- Links with a
[data-swup-preload]
attribute will be preloaded automatically - Hovering a link on pointer devices will preload that link's URL, speeding up load time by a few 100ms. To save server resources, the number of simultaneous preload requests is limited to 5 by default.
- Touch devices will instead preload links at the start of touch events, giving a ~80ms speed-up
- If there is already a preload running, the plugin won't start another one. This saves resources on the server.
Installation
Install the plugin from npm and import it into your bundle.
npm install @swup/preload-plugin
import SwupPreloadPlugin from '@swup/preload-plugin';
Or include the minified production file from a CDN:
<script src="https://unpkg.com/@swup/preload-plugin@2"></script>
Usage
To run this plugin, include an instance in the swup options.
const swup = new Swup({
plugins: [new SwupPreloadPlugin()]
});
Options
throttle
Type: Number
, Default: 5
The concurrency limit for simultaneous requests when hovering links on pointer devices.
Changes of the swup instance
Methods
preloadPage
: Accepts a URL path and returns a promise describing the loading of the page:
const preloadPromise = swup.preloadPage('/path/to/my/page.html');
preloadPages
: Scans the DOM for links with the attribute[data-swup-preload]
and callspreloadPage
for each URL:
swup.preloadPages();
Events
pagePreloaded
: Fires once a page was preloaded:
swup.on('pagePreloaded', (page) => console.log('preloaded:' page));
hoverLink
: fires every time a link is being hovered:
swup.on('hoverLink', (event) => console.log('link hovered:', event));