AgentSkillsCN

svelte5-runes

Svelte 5 的运行时指南。适用于响应式状态、Props 与 Effects 的使用。内容涵盖 $state、$derived、$effect、$props、$bindable,有效避免语法混用与响应式编程中的常见失误。

SKILL.md
--- frontmatter
name: svelte5-runes
description: Svelte 5 runes guidance. Use for reactive state, props, and effects. Covers $state, $derived, $effect, $props, $bindable. Prevents mixing syntaxes and reactivity mistakes.
keywords: [svelte, svelte5, reactivity, state-management, runes, frontend]
disable-model-invocation: false
user-invocable: true

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

svelte
<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:

Notes

  • Event handlers: Use onclick not on:click in Svelte 5
  • Children: Use {@render children()} in layouts
  • Check Svelte version before suggesting syntax
  • Svelte 5.25+ breaking change: $derived can now be reassigned (use const for read-only)
  • Last verified: 2025-01-11
<!-- PROGRESSIVE DISCLOSURE GUIDELINES: - Keep this file ~50 lines total (max ~150 lines) - Use 1-2 code blocks only (recommend 1) - Keep description <200 chars for Level 1 efficiency - Move detailed docs to references/ for Level 3 loading - This is Level 2 - quick reference ONLY, not a manual LLM WORKFLOW (when editing this file): 1. Write/edit SKILL.md 2. Format (if formatter available) 3. Run: claude-skills-cli validate <path> 4. If multi-line description warning: run claude-skills-cli doctor <path> 5. Validate again to confirm -->