svelte5-runes
SKILL.md
Svelte 5 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). Use consistent Svelte 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
Before suggesting code, check these:
- references/reactivity-patterns.md - When to use each rune
- references/component-api.md - $props, $bindable patterns
- references/snippets-vs-slots.md - New snippet syntax
- references/common-mistakes.md - Anti-patterns with fixes
Notes
- Event handlers: Use
onclicknoton:clickin Svelte 5 - Children: Use
{@render children()}in layouts - Check Svelte version before suggesting syntax
- Svelte 5.25+ breaking change:
$derivedcan now be reassigned (useconstfor read-only) - Last verified: 2025-01-11
Weekly Installs
19
Repository
linehaul-ai/lin…ketplaceGitHub Stars
3
First Seen
Jan 24, 2026
Security Audits
Installed on
github-copilot14
opencode14
codex13
gemini-cli13
claude-code12
cursor12