🛠️ Sveltekit
SvelteKitは、Webサイトの見た目から
📺 まず動画で見る(YouTube)
▶ 【衝撃】最強のAIエージェント「Claude Code」の最新機能・使い方・プログラミングをAIで効率化する超実践術を解説! ↗
※ jpskill.com 編集部が参考用に選んだ動画です。動画の内容と Skill の挙動は厳密には一致しないことがあります。
📜 元の英語説明(参考)
Build full-stack web applications with SvelteKit — file-based routing, SSR, SSG, API routes, and form actions in one framework.
🇯🇵 日本人クリエイター向け解説
SvelteKitは、Webサイトの見た目から
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o sveltekit.zip https://jpskill.com/download/3556.zip && unzip -o sveltekit.zip && rm sveltekit.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/3556.zip -OutFile "$d\sveltekit.zip"; Expand-Archive "$d\sveltekit.zip" -DestinationPath $d -Force; ri "$d\sveltekit.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
sveltekit.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
sveltekitフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-17
- 取得日時
- 2026-05-17
- 同梱ファイル
- 1
💬 こう話しかけるだけ — サンプルプロンプト
- › Sveltekit を使って、最小構成のサンプルコードを示して
- › Sveltekit の主な使い方と注意点を教えて
- › Sveltekit を既存プロジェクトに組み込む方法を教えて
これをClaude Code に貼るだけで、このSkillが自動発動します。
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
SvelteKit フルスタック開発
概要
SvelteKit は、Svelte の上に構築された公式のフルスタックフレームワークです。ファイルベースのルーティング、サーバーサイドレンダリング (SSR)、静的サイト生成 (SSG)、API ルート、プログレッシブなフォームアクションをすべて、ブラウザにランタイムオーバーヘッドを一切発生させない Svelte のコンパイル時リアクティビティモデルで提供します。DX とパフォーマンスの両方が重要な、高速でモダンなウェブアプリを構築する際にこのスキルを使用してください。
このスキルを使用するタイミング
- Svelte で新しいフルスタックウェブアプリケーションを構築する際に使用します
- ルートごとにきめ細かな制御が必要な SSR または SSG が必要な場合に使用します
- SPA をサーバー機能を持つフレームワークに移行する際に使用します
- ファイルベースのルーティングと併置された API エンドポイントが必要なプロジェクトで作業する際に使用します
- ユーザーが
+page.svelte、+layout.svelte、load関数、またはフォームアクションについて尋ねた場合に使用します
仕組み
ステップ 1: プロジェクトのセットアップ
npm create svelte@latest my-app
cd my-app
npm install
npm run dev
プロンプトが表示されたら、Skeleton project + TypeScript + ESLint/Prettier を選択してください。
スカフォールディング後のディレクトリ構造:
src/
routes/
+page.svelte ← ルートページコンポーネント
+layout.svelte ← ルートレイアウト (すべてのページをラップします)
+error.svelte ← エラー境界
lib/
server/ ← サーバー専用コード (クライアントにバンドルされません)
components/ ← 共有コンポーネント
app.html ← HTML シェル
static/ ← 静的アセット
ステップ 2: ファイルベースのルーティング
src/routes/ 内のすべての +page.svelte ファイルは、URL に直接マッピングされます。
src/routes/+page.svelte → /
src/routes/about/+page.svelte → /about
src/routes/blog/[slug]/+page.svelte → /blog/:slug
src/routes/shop/[...path]/+page.svelte → /shop/* (キャッチオール)
ルートグループ (URL セグメントなし): (group)/ フォルダーでラップします。
プライベートルート (URL としてアクセス不可): _ または (group) をプレフィックスとして付けます。
ステップ 3: load 関数によるデータの読み込み
ページと一緒に +page.ts (ユニバーサル) または +page.server.ts (サーバー専用) ファイルを使用します。
// src/routes/blog/[slug]/+page.server.ts
import { error } from '@sveltejs/kit';
import type { PageServerLoad } from './$types';
export const load: PageServerLoad = async ({ params, fetch }) => {
const post = await fetch(`/api/posts/${params.slug}`).then(r => r.json());
if (!post) {
error(404, 'Post not found');
}
return { post };
};
<!-- src/routes/blog/[slug]/+page.svelte -->
<script lang="ts">
import type { PageData } from './$types';
export let data: PageData;
</script>
<h1>{data.post.title}</h1>
<article>{@html data.post.content}</article>
ステップ 4: API ルート (サーバーエンドポイント)
REST スタイルのエンドポイント用に +server.ts ファイルを作成します。
// src/routes/api/posts/+server.ts
import { json } from '@sveltejs/kit';
import type { RequestHandler } from './$types';
export const GET: RequestHandler = async ({ url }) => {
const limit = Number(url.searchParams.get('limit') ?? 10);
const posts = await db.post.findMany({ take: limit });
return json(posts);
};
export const POST: RequestHandler = async ({ request }) => {
const body = await request.json();
const post = await db.post.create({ data: body });
return json(post, { status: 201 });
};
ステップ 5: フォームアクション
フォームアクションは、ミューテーションを処理するための SvelteKit ネイティブな方法です。クライアントサイドでのフェッチは不要です。
// src/routes/contact/+page.server.ts
import { fail, redirect } from '@sveltejs/kit';
import type { Actions } from './$types';
export const actions: Actions = {
default: async ({ request }) => {
const data = await request.formData();
const email = data.get('email');
if (!email) {
return fail(400, { email, missing: true });
}
await sendEmail(String(email));
redirect(303, '/thank-you');
}
};
<!-- src/routes/contact/+page.svelte -->
<script lang="ts">
import { enhance } from '$app/forms';
import type { ActionData } from './$types';
export let form: ActionData;
</script>
<form method="POST" use:enhance>
<input name="email" type="email" />
{#if form?.missing}<p class="error">Email is required</p>{/if}
<button type="submit">Subscribe</button>
</form>
ステップ 6: レイアウトとネストされたルート
<!-- src/routes/+layout.svelte -->
<script lang="ts">
import type { LayoutData } from './$types';
export let data: LayoutData;
</script>
<nav>
<a href="/">Home</a>
<a href="/blog">Blog</a>
{#if data.user}
<a href="/dashboard">Dashboard</a>
{/if}
</nav>
<slot /> <!-- 子ページはここにレンダリングされます -->
// src/routes/+layout.server.ts
import type { LayoutServerLoad } from './$types';
export const load: LayoutServerLoad = async ({ locals }) => {
return { user: locals.user ?? null };
};
ステップ 7: レンダリングモード
ページオプションでルートごとのレンダリングを制御します。
// src/routes/docs/+page.ts
export const prerender = true; // 静的 — ビルド時に生成されます
export const ssr = true; // デフォルト — リクエストごとにサーバーでレンダリングされます
export const csr = false; // クライアントサイドのハイドレーションを完全に無効にします
例
例 1: 保護されたダッシュボードルート
// src/routes/dashboard/+layout.server.ts
import { redirect } from '@sveltejs/kit';
import type { LayoutServerLoad } from './$types';
export const load: LayoutServerLoad = async ({ locals }) => {
if (!locals.user) {
redirect(303, '/login');
}
return { user: locals.user };
};
例 2: フック — セッションミドルウェア
// src/hooks.server.ts
import type { Handle } from '@sveltejs/kit';
import { verifyToken } from '$lib/server/auth';
export const handle: Handle = async ({ event, resolve }) => {
const token = event.cookies.get('session');
if (token) {
event.locals.user = await verifyToken(token);
}
return resolve(event);
};
例 3: プリロードと無効化
<script lang="ts">
import { invalidateAl 📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
SvelteKit Full-Stack Development
Overview
SvelteKit is the official full-stack framework built on top of Svelte. It provides file-based routing, server-side rendering (SSR), static site generation (SSG), API routes, and progressive form actions — all with Svelte's compile-time reactivity model that ships zero runtime overhead to the browser. Use this skill when building fast, modern web apps where both DX and performance matter.
When to Use This Skill
- Use when building a new full-stack web application with Svelte
- Use when you need SSR or SSG with fine-grained control per route
- Use when migrating a SPA to a framework with server capabilities
- Use when working on a project that needs file-based routing and collocated API endpoints
- Use when the user asks about
+page.svelte,+layout.svelte,loadfunctions, or form actions
How It Works
Step 1: Project Setup
npm create svelte@latest my-app
cd my-app
npm install
npm run dev
Choose Skeleton project + TypeScript + ESLint/Prettier when prompted.
Directory structure after scaffolding:
src/
routes/
+page.svelte ← Root page component
+layout.svelte ← Root layout (wraps all pages)
+error.svelte ← Error boundary
lib/
server/ ← Server-only code (never bundled to client)
components/ ← Shared components
app.html ← HTML shell
static/ ← Static assets
Step 2: File-Based Routing
Every +page.svelte file in src/routes/ maps directly to a URL:
src/routes/+page.svelte → /
src/routes/about/+page.svelte → /about
src/routes/blog/[slug]/+page.svelte → /blog/:slug
src/routes/shop/[...path]/+page.svelte → /shop/* (catch-all)
Route groups (no URL segment): wrap in (group)/ folder.
Private routes (not accessible as URLs): prefix with _ or (group).
Step 3: Loading Data with load Functions
Use a +page.ts (universal) or +page.server.ts (server-only) file alongside the page:
// src/routes/blog/[slug]/+page.server.ts
import { error } from '@sveltejs/kit';
import type { PageServerLoad } from './$types';
export const load: PageServerLoad = async ({ params, fetch }) => {
const post = await fetch(`/api/posts/${params.slug}`).then(r => r.json());
if (!post) {
error(404, 'Post not found');
}
return { post };
};
<!-- src/routes/blog/[slug]/+page.svelte -->
<script lang="ts">
import type { PageData } from './$types';
export let data: PageData;
</script>
<h1>{data.post.title}</h1>
<article>{@html data.post.content}</article>
Step 4: API Routes (Server Endpoints)
Create +server.ts files for REST-style endpoints:
// src/routes/api/posts/+server.ts
import { json } from '@sveltejs/kit';
import type { RequestHandler } from './$types';
export const GET: RequestHandler = async ({ url }) => {
const limit = Number(url.searchParams.get('limit') ?? 10);
const posts = await db.post.findMany({ take: limit });
return json(posts);
};
export const POST: RequestHandler = async ({ request }) => {
const body = await request.json();
const post = await db.post.create({ data: body });
return json(post, { status: 201 });
};
Step 5: Form Actions
Form actions are the SvelteKit-native way to handle mutations — no client-side fetch required:
// src/routes/contact/+page.server.ts
import { fail, redirect } from '@sveltejs/kit';
import type { Actions } from './$types';
export const actions: Actions = {
default: async ({ request }) => {
const data = await request.formData();
const email = data.get('email');
if (!email) {
return fail(400, { email, missing: true });
}
await sendEmail(String(email));
redirect(303, '/thank-you');
}
};
<!-- src/routes/contact/+page.svelte -->
<script lang="ts">
import { enhance } from '$app/forms';
import type { ActionData } from './$types';
export let form: ActionData;
</script>
<form method="POST" use:enhance>
<input name="email" type="email" />
{#if form?.missing}<p class="error">Email is required</p>{/if}
<button type="submit">Subscribe</button>
</form>
Step 6: Layouts and Nested Routes
<!-- src/routes/+layout.svelte -->
<script lang="ts">
import type { LayoutData } from './$types';
export let data: LayoutData;
</script>
<nav>
<a href="/">Home</a>
<a href="/blog">Blog</a>
{#if data.user}
<a href="/dashboard">Dashboard</a>
{/if}
</nav>
<slot /> <!-- child page renders here -->
// src/routes/+layout.server.ts
import type { LayoutServerLoad } from './$types';
export const load: LayoutServerLoad = async ({ locals }) => {
return { user: locals.user ?? null };
};
Step 7: Rendering Modes
Control per-route rendering with page options:
// src/routes/docs/+page.ts
export const prerender = true; // Static — generated at build time
export const ssr = true; // Default — rendered on server per request
export const csr = false; // Disable client-side hydration entirely
Examples
Example 1: Protected Dashboard Route
// src/routes/dashboard/+layout.server.ts
import { redirect } from '@sveltejs/kit';
import type { LayoutServerLoad } from './$types';
export const load: LayoutServerLoad = async ({ locals }) => {
if (!locals.user) {
redirect(303, '/login');
}
return { user: locals.user };
};
Example 2: Hooks — Session Middleware
// src/hooks.server.ts
import type { Handle } from '@sveltejs/kit';
import { verifyToken } from '$lib/server/auth';
export const handle: Handle = async ({ event, resolve }) => {
const token = event.cookies.get('session');
if (token) {
event.locals.user = await verifyToken(token);
}
return resolve(event);
};
Example 3: Preloading and Invalidation
<script lang="ts">
import { invalidateAll } from '$app/navigation';
async function refresh() {
await invalidateAll(); // re-runs all load functions on the page
}
</script>
<button on:click={refresh}>Refresh</button>
Best Practices
- ✅ Use
+page.server.tsfor database/auth logic — it never ships to the client - ✅ Use
$lib/server/for shared server-only modules (DB client, auth helpers) - ✅ Use form actions for mutations instead of client-side
fetch— works without JS - ✅ Type all
loadreturn values with generated$types(PageData,LayoutData) - ✅ Use
event.localsin hooks to pass server-side context to load functions - ❌ Don't import server-only code in
+page.svelteor+layout.sveltedirectly - ❌ Don't store sensitive state in stores — use
localson the server - ❌ Don't skip
use:enhanceon forms — without it, forms lose progressive enhancement
Security & Safety Notes
- All code in
+page.server.ts,+server.ts, and$lib/server/runs exclusively on the server — safe for DB queries, secrets, and session validation. - Always validate and sanitize form data before database writes.
- Use
error(403)orredirect(303)from@sveltejs/kitrather than returning raw error objects. - Set
httpOnly: trueandsecure: trueon all auth cookies. - CSRF protection is built-in for form actions — do not disable
checkOriginin production.
Common Pitfalls
-
Problem:
Cannot use import statement in a modulein+page.server.tsSolution: The file must be.tsor.js, not.svelte. Server files and Svelte components are separate. -
Problem: Store value is
undefinedon first SSR render Solution: Populate the store from theloadfunction return value (dataprop), not from client-sideonMount. -
Problem: Form action does not redirect after submit Solution: Use
redirect(303, '/path')from@sveltejs/kit, not a plainreturn. 303 is required for POST redirects. -
Problem:
locals.useris undefined inside a+page.server.tsload function Solution: Setevent.locals.userinsrc/hooks.server.tsbefore theresolve()call.
Related Skills
@nextjs-app-router-patterns— When you prefer React over Svelte for SSR/SSG@trpc-fullstack— Add end-to-end type safety to SvelteKit API routes@auth-implementation-patterns— Authentication patterns usable with SvelteKit hooks@tailwind-patterns— Styling SvelteKit apps with Tailwind CSS
Limitations
- Use this skill only when the task clearly matches the scope described above.
- Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
- Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.