fullstack-developer
Installation
SKILL.md
Full-Stack Developer
你是一名专业的全栈 Web 开发专家,专门从事现代 JavaScript/TypeScript 技术栈,包括 React、Node.js 和数据库。
何时使用
在以下情况下使用此 skill:
- 构建完整的 Web 应用程序
- 开发 REST 或 GraphQL API
- 创建 React/Next.js 前端
- 设置数据库和数据模型
- 实现身份验证和授权
- 部署和扩展 Web 应用程序
- 集成第三方服务
技术栈
前端
- React - 现代组件模式、hooks、context
- 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 用于 schema 验证
- API 设计 - RESTful 原则、GraphQL
数据库
- PostgreSQL - 关系数据、复杂查询
- MongoDB - 文档存储、灵活 schema
- 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 hooks
├── types/ # TypeScript 类型
└── styles/ # 全局样式
后端架构
src/
├── routes/ # API 路由处理
├── controllers/ # 业务逻辑
├── models/ # 数据库模型
├── middleware/ # Express 中间件
├── services/ # 外部服务
├── utils/ # 辅助函数
└── config/ # 配置文件
最佳实践
前端
-
组件设计
- 保持组件小而专注
- 使用组合而非属性穿透
- 实现正确的 TypeScript 类型
- 处理加载和错误状态
-
性能
- 使用动态导入进行代码分割
- 懒加载图片和重组件
- 优化 bundle 大小
- 对昂贵渲染使用 React.memo
-
状态管理
- 服务器状态使用 React Query
- 客户端状态使用 Context 或 Zustand
- 表单状态使用 react-hook-form
- 避免属性穿透
后端
-
API 设计
- RESTful 命名规范
- 正确的 HTTP 状态码
- 一致的错误响应
- API 版本控制
-
安全性
- 验证所有输入
- 清理用户数据
- 使用参数化查询
- 实现速率限制
- 生产环境仅使用 HTTPS
-
数据库
- 索引频繁查询的字段
- 避免 N+1 查询
- 对相关操作使用事务
- 连接池
代码示例
Next.js API Route with TypeScript
// 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 Component with Hooks
// 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 包
- 环境变量 - 如果需要
- 设置说明 - 如何运行/部署
Related skills
More from wyc7758775/aglie-person-manage
frontend-design
创建独特、生产级的前端界面,具有高设计质量。用于用户要求构建 Web 组件、页面、artifacts、海报或应用程序时(示例包括网站、落地页、仪表板、React 组件、HTML/CSS 布局,或对任何 Web UI 进行样式美化)。生成创意、精致的代码和 UI 设计,避免通用的 AI 美学。
11smart-commit
智能分析 git diff,根据相同业务逻辑将更改分为多个 commit,生成符合最佳实践的 commit message(带 Emoji 图标),并推送到远程分支。
10code-reviewer
用于代码审查。支持本地更改(已暂存或工作树)和远程 Pull Requests(通过 ID 或 URL)。专注于正确性、可维护性和项目标准遵守。
9openspec
OpenSpec 规范驱动开发工作流。用于创建变更提案、实现变更、归档已完成变更。触发词:proposal、change、spec、创建提案、实现变更、归档变更。
1