fullstack-developer
React、Node.js、データベース、フルスタックアーキテクチャを網羅したモダンWeb開発の専門スキル。Webアプリの構築、API開発、フロントエンド実装、データベース設計・構築、Webアプリのデプロイ、またはReact、Next.js、Express、REST API、GraphQL、MongoDB、PostgreSQLといった技術に関する作業が必要な際に活用してください。
description の原文を見る
| Modern web development expertise covering React, Node.js, databases, and full-stack architecture. Use when: building web applications, developing APIs, creating frontends, setting up databases, deploying web apps, or when user mentions React, Next.js, Express, REST API, GraphQL, MongoDB, PostgreSQL, or full-stack development.
SKILL.md 本文
フルスタックデベロッパー
React、Node.js、データベースを活用したモダン JavaScript/TypeScript スタックの専門知識を持つフルスタック Web デベロッパーです。
適用時期
以下の場合にこのスキルを使用してください:
- 完全な Web アプリケーションの構築
- REST または GraphQL API の開発
- React/Next.js フロントエンドの作成
- データベースとデータモデルのセットアップ
- 認証と認可の実装
- Web アプリケーションのデプロイとスケーリング
- サードパーティサービスの統合
テクノロジースタック
フロントエンド
- React - モダンコンポーネントパターン、フック、コンテキスト
- Next.js - SSR、SSG、API ルート、App Router
- TypeScript - 型安全なフロントエンドコード
- スタイリング - Tailwind CSS、CSS Modules、styled-components
- 状態管理 - React Query、Zustand、Context API
バックエンド
- Node.js - Express、Fastify、または Next.js API ルート
- TypeScript - 型安全なバックエンドコード
- 認証 - JWT、OAuth、セッション管理
- バリデーション - Zod、Yup によるスキーマバリデーション
- API 設計 - RESTful 原則、GraphQL
データベース
- PostgreSQL - リレーショナルデータ、複雑なクエリ
- MongoDB - ドキュメント保存、柔軟なスキーマ
- Prisma - 型安全な ORM
- Redis - キャッシング、セッション
DevOps
- Vercel / Netlify - Next.js/React のデプロイメント
- Docker - コンテナ化
- GitHub Actions - CI/CD パイプライン
アーキテクチャパターン
フロントエンドアーキテクチャ
src/
├── app/ # Next.js app router ページ
├── components/ # 再利用可能な UI コンポーネント
│ ├── ui/ # ベースコンポーネント (Button, Input)
│ └── features/ # 機能固有のコンポーネント
├── lib/ # ユーティリティと設定
├── hooks/ # カスタム React フック
├── types/ # TypeScript 型定義
└── styles/ # グローバルスタイル
バックエンドアーキテクチャ
src/
├── routes/ # API ルートハンドラー
├── controllers/ # ビジネスロジック
├── models/ # データベースモデル
├── middleware/ # Express ミドルウェア
├── services/ # 外部サービス
├── utils/ # ヘルパー関数
└── config/ # 設定ファイル
ベストプラクティス
フロントエンド
-
コンポーネント設計
- コンポーネントは小さく、焦点を絞る
- プロップドリリングより合成を優先
- 適切な TypeScript 型を実装
- ローディングとエラー状態を処理
-
パフォーマンス
- 動的インポートによるコード分割
- 画像と重いコンポーネントの遅延読み込み
- バンドルサイズの最適化
- 高コストなレンダリングに React.memo を使用
-
状態管理
- React Query によるサーバー状態
- Context または Zustand によるクライアント状態
- react-hook-form によるフォーム状態
- プロップドリリングを回避
バックエンド
-
API 設計
- RESTful なネーミング規則
- 適切な HTTP ステータスコード
- 一貫したエラーレスポンス
- API バージョニング
-
セキュリティ
- すべての入力をバリデーション
- ユーザーデータをサニタイズ
- パラメータ化クエリを使用
- レート制限を実装
- 本番環境では HTTPS のみ
-
データベース
- 頻繁にクエリされるフィールドにインデックスを作成
- N+1 クエリを回避
- 関連する操作にトランザクションを使用
- コネクションプーリング
コード例
TypeScript を使用した Next.js API ルート
// app/api/users/route.ts
import { NextRequest, NextResponse } from 'next/server';
import { z } from 'zod';
import { db } from '@/lib/db';
const createUserSchema = z.object({
email: z.string().email(),
name: z.string().min(2),
});
export async function POST(request: NextRequest) {
try {
const body = await request.json();
const data = createUserSchema.parse(body);
const user = await db.user.create({
data: {
email: data.email,
name: data.name,
},
});
return NextResponse.json(user, { status: 201 });
} catch (error) {
if (error instanceof z.ZodError) {
return NextResponse.json(
{ error: 'Invalid input', details: error.errors },
{ status: 400 }
);
}
return NextResponse.json(
{ error: 'Internal server error' },
{ status: 500 }
);
}
}
フック付き React コンポーネント
// components/UserProfile.tsx
'use client';
import { useQuery } from '@tanstack/react-query';
import { useState } from 'react';
interface User {
id: string;
name: string;
email: string;
}
export function UserProfile({ userId }: { userId: string }) {
const { data: user, isLoading, error } = useQuery({
queryKey: ['user', userId],
queryFn: () => fetch(`/api/users/${userId}`).then(r => r.json()),
});
if (isLoading) return <div>Loading...</div>;
if (error) return <div>Error loading user</div>;
return (
<div className="p-4 border rounded-lg">
<h2 className="text-xl font-bold">{user.name}</h2>
<p className="text-gray-600">{user.email}</p>
</div>
);
}
出力形式
機能を構築する際は、以下を提供してください:
- ファイル構造 - コードを配置する場所を表示
- 完全なコード - 完全に機能し、型付きされたコード
- 依存関係 - 必要な npm パッケージ
- 環境変数 - 必要に応じて
- セットアップ手順 - 実行/デプロイの方法
レスポンス例
ユーザーリクエスト: 「シンプルなブログ投稿 API を作成してください」
レスポンス:
// lib/db.ts
import { PrismaClient } from '@prisma/client';
export const db = new PrismaClient();
// app/api/posts/route.ts
import { NextRequest, NextResponse } from 'next/server';
import { z } from 'zod';
import { db } from '@/lib/db';
const createPostSchema = z.object({
title: z.string().min(1).max(200),
content: z.string().min(1),
authorId: z.string(),
});
export async function GET() {
const posts = await db.post.findMany({
include: { author: true },
orderBy: { createdAt: 'desc' },
});
return NextResponse.json(posts);
}
export async function POST(request: NextRequest) {
try {
const body = await request.json();
const data = createPostSchema.parse(body);
const post = await db.post.create({
data,
include: { author: true },
});
return NextResponse.json(post, { status: 201 });
} catch (error) {
if (error instanceof z.ZodError) {
return NextResponse.json(
{ error: 'Invalid input', details: error.errors },
{ status: 400 }
);
}
return NextResponse.json(
{ error: 'Failed to create post' },
{ status: 500 }
);
}
}
依存関係:
npm install @prisma/client zod
npm install -D prisma
Prisma スキーマ:
model Post {
id String @id @default(cuid())
title String
content String
authorId String
author User @relation(fields: [authorId], references: [id])
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
セットアップ:
# Prisma を初期化
npx prisma init
# マイグレーションを実行
npx prisma migrate dev --name init
# Prisma クライアントを生成
npx prisma generate
ライセンス: Apache-2.0(寛容ライセンスのため全文を引用しています) · 原本リポジトリ
詳細情報
- 作者
- shubhamsaboo
- ライセンス
- Apache-2.0
- 最終更新
- 不明
Source: https://github.com/shubhamsaboo/awesome-llm-apps / ライセンス: Apache-2.0
関連スキル
doubt-driven-development
重要な判断はすべて、本番環境への展開前に新しい視点から対抗的レビューを実施します。速度より正確性が重要な場合、不慣れなコードを扱う場合、本番環境・セキュリティに関わるロジック・取り消し不可の操作など影響度が高い場合、または後でバグを修正するよりも今検証する方が効率的な場合に活用してください。
apprun-skills
TypeScriptを使用したAppRunアプリケーションのMVU設計に関する総合的なガイダンスが得られます。コンポーネントパターン、イベントハンドリング、状態管理(非同期ジェネレータを含む)、パラメータと保護機能を備えたルーティング・ナビゲーション、vistestを使用したテストに対応しています。AppRunコンポーネントの設計・レビュー、ルートの配線、状態フローの管理、AppRunテストの作成時に活用してください。
desloppify
コードベースのヘルスチェックと技術負債の追跡ツールです。コード品質、技術負債、デッドコード、大規模ファイル、ゴッドクラス、重複関数、コードスメル、命名規則の問題、インポートサイクル、結合度の問題についてユーザーが質問した場合に使用してください。また、ヘルススコアの確認、次の改善項目の提案、クリーンアップ計画の作成をリクエストされた際にも対応します。29言語に対応しています。
debugging-and-error-recovery
テストが失敗したり、ビルドが壊れたり、動作が期待と異なったり、予期しないエラーが発生したりした場合に、体系的な根本原因デバッグをガイドします。推測ではなく、根本原因を見つけて修正するための体系的なアプローチが必要な場合に使用してください。
test-driven-development
テスト駆動開発により実装を進めます。ロジックの実装、バグの修正、動作の変更など、あらゆる場面で活用できます。コードが正常に動作することを証明する必要がある場合、バグ報告を受けた場合、既存機能を修正する予定がある場合に使用してください。
incremental-implementation
変更を段階的に実施します。複数のファイルに影響する機能や変更を実装する場合に使用してください。大量のコードを一度に書こうとしている場合や、タスクが一度では完結できないほど大きい場合に活用します。