View Transitions
Add <ViewTransitions /> to a shared layout to animate full-page navigations via the browser's cross-document View Transitions API — no client router. The card animates while the video below is held still and keeps playing across the navigation, resuming at the same timestamp.
Page 2
Each navigation is a full page load — the browser animates it with a blur transition.
<script lang="ts">
import { url } from 'mochi-framework';
import { ViewTransitions } from 'mochi-framework/components';
import TransitionCard from './TransitionCard.svelte';
const type = parseTransition(url.searchParams.get('type'));
</script>
<ViewTransitions {type} regions="card" />
<TransitionCard page={1} {type} />
More demos
Hello World The simplest possible Mochi page — pure server-rendered Svelte. Unique IDs Svelte's native $props.id() inside islands — SSR-consistent, unique per instance, namespaced in server islands. Cancelling form submissions cancel() prevents the fetch from firing; controller.abort() stops one mid-flight.