Options
Swup has several options that can be passed in during initialization.
Defaults
These are the default options. See below for details on each option.
const swup = new Swup({
animateHistoryBrowsing: false,
animationSelector: '[class*="transition-"]',
animationScope: 'html',
cache: true,
containers: ['#swup'],
hooks: {},
ignoreVisit: (url, { el } = {}) => el?.closest('[data-no-swup]'),
linkSelector: 'a[href]',
linkToSelf: 'scroll',
native: false,
plugins: [],
resolveUrl: (url) => url,
requestHeaders: {
'X-Requested-With': 'swup',
'Accept': 'text/html, application/xhtml+xml'
},
skipPopStateHandling: (event) => event.state?.source !== 'swup',
timeout: 0
});
const swup = new Swup({
animateHistoryBrowsing: false,
animationSelector: '[class*="transition-"]',
animationScope: 'html',
cache: true,
containers: ['#swup'],
hooks: {},
ignoreVisit: (url, { el } = {}) => el?.closest('[data-no-swup]'),
linkSelector: 'a[href]',
linkToSelf: 'scroll',
native: false,
plugins: [],
resolveUrl: (url) => url,
requestHeaders: {
'X-Requested-With': 'swup',
'Accept': 'text/html, application/xhtml+xml'
},
skipPopStateHandling: (event) => event.state?.source !== 'swup',
timeout: 0
});
animationSelector
The selector for detecting animation timing. Swup will wait for all CSS transitions and
keyframe animations to finish on these elements before swapping in the content of the new page.
The default option will select all elements with class names beginning in transition-
.
{
animationSelector: '[class*="transition-"]'
}
{
animationSelector: '[class*="transition-"]'
}
animationScope
The elements on which swup will add the animation classes
for styling the different phases of the in/out animation. By default, it will add those classes
to the html
tag. This is great for most use cases and the recommended way to use swup.
{
animationScope: 'html'
}
{
animationScope: 'html'
}
<html class="is-animating is-leaving"></html>
<html class="is-animating is-leaving"></html>
Setting this option to containers
will add the classes on the content containers themselves instead.
{
animationScope: 'containers'
}
{
animationScope: 'containers'
}
<main id="swup" class="is-animating is-leaving">Content</main>
<main id="swup" class="is-animating is-leaving">Content</main>
containers
The content containers to be replaced on page visits. Usually the <main>
element with the
content of the page, but can include any other elements that are present across all pages.
Defaults to a single container of id #swup
.
Adding containers here allows animating one set of elements while replacing other parts of the page without animation, e.g. a global site navigation that will not fade out but still needs to update to reflect language changes.
{
containers: ['#swup']
}
{
containers: ['#swup']
}
cache
The built-in cache keeps previously loaded pages in memory. This improves speed but
can be disabled for highly dynamic sites that need up-to-date responses on each request. Defaults
to true
.
{
cache: true
}
{
cache: true
}
hooks
An object of hook handlers to register. For details and a few more examples, see the section on registering all hooks handlers at once.
{
hooks: {
'visit:start': () => console.log('start'),
'visit:end': () => console.log('end')
}
}
{
hooks: {
'visit:start': () => console.log('start'),
'visit:end': () => console.log('end')
}
}
ignoreVisit
Allows ignoring specific visits via callback. By default, swup will ignore links with a
data-no-swup
attribute on itself or any parent element.
The callback takes a relative URL of the new page, as well as the element and event that triggered
the visit. Note that element and event will be undefined if navigating via swup.navigate(url)
.
{
ignoreVisit: (url, { el, event } = {}) => el?.closest('[data-no-swup]')
}
{
ignoreVisit: (url, { el, event } = {}) => el?.closest('[data-no-swup]')
}
linkSelector
The link elements that trigger visits. By default, all a
elements with an href
attribute will receive clicks.
{
linkSelector: 'a[href]'
}
{
linkSelector: 'a[href]'
}
To let swup take over clicks on map areas or SVG links, append the selector:
{
linkSelector: 'a[href], area[href], svg a[*|href]'
}
{
linkSelector: 'a[href], area[href], svg a[*|href]'
}
linkToSelf
How swup handles links that lead to the currently active URL. By default, it will scroll
to the
top without actually performing a navigation. Pass in navigate
to treat these links like any
other link and perform a regular navigation.
{
linkToSelf: 'navigate'
}
{
linkToSelf: 'navigate'
}
native
Enable native animations using the View Transitions
API. This will toggle the class swup-native
on the HTML element if View Transitions are supported
by the user's browsers. Learn more about native view transitions.
requestHeaders
The custom headers that get sent along with each swup request.
{
requestHeaders: {
'X-Requested-With': 'swup', // identify swup requests
'Accept': 'text/html, application/xhtml+xml' // define expected response
}
}
{
requestHeaders: {
'X-Requested-With': 'swup', // identify swup requests
'Accept': 'text/html, application/xhtml+xml' // define expected response
}
}
resolveUrl
Rewrite URLs before loading them. An advanced way of ignoring certain visits by mapping different paths to a single path and treating them as one resource for fetching pages and restoring scroll positions. The callback receives and returns a relative URL.
An example use case would be a project listing: the server always sends the complete list of
projects and filtering is done client-side based on query params. You'll want to handle any visits
between /projects/?sort=date
and /projects/?sort=title
yourself, telling swup nothing has
changed and no page load is necessary.
{
resolveUrl: (url) => {
if (url.startsWith('/projects/?')) {
return '/projects/';
}
return url;
}
}
{
resolveUrl: (url) => {
if (url.startsWith('/projects/?')) {
return '/projects/';
}
return url;
}
}
The option defaults to (url) => url
.
skipPopStateHandling
Swup will only handle backward/forward visits to history entries it has created itself. Any visits
to entries without a custom source
property will be ignored and handled by the browser instead.
To modify this behavior, provide a custom callback function that receives the popstate
event
and returns a boolean
.
{
skipPopStateHandling: (event) => event.state?.source !== 'swup'
}
{
skipPopStateHandling: (event) => event.state?.source !== 'swup'
}
timeout
Swup allows setting a fetch timeout in milliseconds. If a page takes longer to load than specified,
swup triggers a fetch:timeout
hook and defers to a standard browser page load. Disabled by default.
{
timeout: 10_000
}
{
timeout: 10_000
}
animateHistoryBrowsing
Swup will skip animations for visits triggered by the back/forward button. If you do require
animations on history visits, set this to true
. Swup will add the class is-popstate
to the html
tag during those animations. Defaults to false
.
{
animateHistoryBrowsing: false
}
{
animateHistoryBrowsing: false
}