svelte-runes

star 213

Svelte runes guidance. Use for reactive state, props, effects, attachments, or migration. Covers $state, $derived, $effect, @attach. Prevents reactivity mistakes.

spences10 By spences10 schedule Updated 12/14/2025

name: svelte-runes

IMPORTANT: Keep description on ONE line for Claude Code compatibility

prettier-ignore

description: Svelte runes guidance. Use for reactive state, props, effects, attachments, or migration. Covers $state, $derived, $effect, @attach. Prevents reactivity mistakes.

Svelte Runes

Quick Start

Which rune? Props: $props() | Bindable: $bindable() | Computed: $derived() | Side effect: $effect() | State: $state()

Key rules: Runes are top-level only. $derived can be overridden (use const for read-only). Don't mix Svelte 4/5 syntax. Objects/arrays are deeply reactive by default.

Example

<script>
    let count = $state(0); // Mutable state
    const doubled = $derived(count * 2); // Computed (const = read-only)

    $effect(() => {
        console.log(`Count is ${count}`); // Side effect
    });
</script>

<button onclick={() => count++}>
    {count} (doubled: {doubled})
</button>

Reference Files

Notes

  • Use onclick not on:click, {@render children()} in layouts
  • $derived can be reassigned (5.25+) - use const for read-only
  • Last verified: 2025-01-11
Install via CLI
npx skills add https://github.com/spences10/svelte-claude-skills --skill svelte-runes
Repository Details
star Stars 213
call_split Forks 20
navigation Branch main
article Path SKILL.md
More from Creator