Build and deploy
Single-page apps
Edit this page on GitHubYou can turn any SvelteKit app, using any adapter, into a fully client-rendered single-page app (SPA) by disabling SSR at the root layout:
tsssr = false;
tsssr = false;
In most situations this is not recommended: it harms SEO, tends to slow down perceived performance, and makes your app inaccessible to users if JavaScript fails or is disabled (which happens more often than you probably think).
If you don't have any server-side logic (i.e. +page.server.js, +layout.server.js or +server.js files) you can use adapter-static to create your SPA by adding a fallback page.
Usagepermalink
Install with npm i -D @sveltejs/adapter-static, then add the adapter to your svelte.config.js with the following options:
tsadapter from'@sveltejs/adapter-static' ;export default {kit : {adapter :adapter ({fallback : '200.html' // may differ from host to host})}};
The fallback page is an HTML page created by SvelteKit from your page template (e.g. app.html) that loads your app and navigates to the correct route. For example Surge, a static web host, lets you add a 200.html file that will handle any requests that don't correspond to static assets or prerendered pages.
On some hosts it may be index.html or something else entirely — consult your platform's documentation.
Apachepermalink
To run an SPA on Apache, you should add a static/.htaccess file to route requests to the fallback page:
<IfModule mod_rewrite.c>
	RewriteEngine On
	RewriteBase /
	RewriteRule ^200\.html$ - [L]
	RewriteCond %{REQUEST_FILENAME} !-f
	RewriteCond %{REQUEST_FILENAME} !-d
	RewriteRule . /200.html [L]
</IfModule>Prerendering individual pagespermalink
If you want certain pages to be prerendered, you can re-enable ssr alongside prerender for just those parts of your app:
tsprerender = true;export constssr = true;
tsprerender = true;export constssr = true;