# markdown-editor
**Repository Path**: qfc_1/markdown-editor
## Basic Information
- **Project Name**: markdown-editor
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2026-01-20
- **Last Updated**: 2026-02-13
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# projects
这是一个基于 [Next.js 16](https://nextjs.org) + [shadcn/ui](https://ui.shadcn.com) 的全栈应用项目,由扣子编程 CLI 创建。
## 快速开始
### 启动开发服务器
```bash
coze dev
```
启动后,在浏览器中打开 [http://localhost:5000](http://localhost:5000) 查看应用。
开发服务器支持热更新,修改代码后页面会自动刷新。
### 构建生产版本
```bash
coze build
```
### 启动生产服务器
```bash
coze start
```
## 项目结构
```
src/
├── app/ # Next.js App Router 目录
│ ├── layout.tsx # 根布局组件
│ ├── page.tsx # 首页
│ ├── globals.css # 全局样式(包含 shadcn 主题变量)
│ └── [route]/ # 其他路由页面
├── components/ # React 组件目录
│ └── ui/ # shadcn/ui 基础组件(优先使用)
│ ├── button.tsx
│ ├── card.tsx
│ └── ...
├── lib/ # 工具函数库
│ └── utils.ts # cn() 等工具函数
└── hooks/ # 自定义 React Hooks(可选)
```
## 核心开发规范
### 1. 组件开发
**优先使用 shadcn/ui 基础组件**
本项目已预装完整的 shadcn/ui 组件库,位于 `src/components/ui/` 目录。开发时应优先使用这些组件作为基础:
```tsx
// ✅ 推荐:使用 shadcn 基础组件
import { Button } from '@/components/ui/button';
import { Card, CardContent, CardHeader } from '@/components/ui/card';
import { Input } from '@/components/ui/input';
export default function MyComponent() {
return (
标题
);
}
```
**可用的 shadcn 组件清单**
- 表单:`button`, `input`, `textarea`, `select`, `checkbox`, `radio-group`, `switch`, `slider`
- 布局:`card`, `separator`, `tabs`, `accordion`, `collapsible`, `scroll-area`
- 反馈:`alert`, `alert-dialog`, `dialog`, `toast`, `sonner`, `progress`
- 导航:`dropdown-menu`, `menubar`, `navigation-menu`, `context-menu`
- 数据展示:`table`, `avatar`, `badge`, `hover-card`, `tooltip`, `popover`
- 其他:`calendar`, `command`, `carousel`, `resizable`, `sidebar`
详见 `src/components/ui/` 目录下的具体组件实现。
### 2. 路由开发
Next.js 使用文件系统路由,在 `src/app/` 目录下创建文件夹即可添加路由:
```bash
# 创建新路由 /about
src/app/about/page.tsx
# 创建动态路由 /posts/[id]
src/app/posts/[id]/page.tsx
# 创建路由组(不影响 URL)
src/app/(marketing)/about/page.tsx
# 创建 API 路由
src/app/api/users/route.ts
```
**页面组件示例**
```tsx
// src/app/about/page.tsx
import { Button } from '@/components/ui/button';
export const metadata = {
title: '关于我们',
description: '关于页面描述',
};
export default function AboutPage() {
return (
关于我们
);
}
```
**动态路由示例**
```tsx
// src/app/posts/[id]/page.tsx
export default async function PostPage({
params,
}: {
params: Promise<{ id: string }>;
}) {
const { id } = await params;
return 文章 ID: {id}
;
}
```
**API 路由示例**
```tsx
// src/app/api/users/route.ts
import { NextResponse } from 'next/server';
export async function GET() {
return NextResponse.json({ users: [] });
}
export async function POST(request: Request) {
const body = await request.json();
return NextResponse.json({ success: true });
}
```
### 3. 依赖管理
**必须使用 pnpm 管理依赖**
```bash
# ✅ 安装依赖
pnpm install
# ✅ 添加新依赖
pnpm add package-name
# ✅ 添加开发依赖
pnpm add -D package-name
# ❌ 禁止使用 npm 或 yarn
# npm install # 错误!
# yarn add # 错误!
```
项目已配置 `preinstall` 脚本,使用其他包管理器会报错。
### 4. 样式开发
**使用 Tailwind CSS v4**
本项目使用 Tailwind CSS v4 进行样式开发,并已配置 shadcn 主题变量。
```tsx
// 使用 Tailwind 类名
// 使用 cn() 工具函数合并类名
import { cn } from '@/lib/utils';
内容
```
**主题变量**
主题变量定义在 `src/app/globals.css` 中,支持亮色/暗色模式:
- `--background`, `--foreground`
- `--primary`, `--primary-foreground`
- `--secondary`, `--secondary-foreground`
- `--muted`, `--muted-foreground`
- `--accent`, `--accent-foreground`
- `--destructive`, `--destructive-foreground`
- `--border`, `--input`, `--ring`
### 5. 表单开发
推荐使用 `react-hook-form` + `zod` 进行表单开发:
```tsx
import { useForm } from 'react-hook-form';
import { zodResolver } from '@hookform/resolvers/zod';
import * as z from 'zod';
import { Button } from '@/components/ui/button';
import { Input } from '@/components/ui/input';
const formSchema = z.object({
username: z.string().min(2, '用户名至少 2 个字符'),
email: z.string().email('请输入有效的邮箱'),
});
export default function MyForm() {
const form = useForm({
resolver: zodResolver(formSchema),
defaultValues: { username: '', email: '' },
});
const onSubmit = (data: z.infer) => {
console.log(data);
};
return (
);
}
```
### 6. 数据获取
**服务端组件(推荐)**
```tsx
// src/app/posts/page.tsx
async function getPosts() {
const res = await fetch('https://api.example.com/posts', {
cache: 'no-store', // 或 'force-cache'
});
return res.json();
}
export default async function PostsPage() {
const posts = await getPosts();
return (
{posts.map(post => (
{post.title}
))}
);
}
```
**客户端组件**
```tsx
'use client';
import { useEffect, useState } from 'react';
export default function ClientComponent() {
const [data, setData] = useState(null);
useEffect(() => {
fetch('/api/data')
.then(res => res.json())
.then(setData);
}, []);
return {JSON.stringify(data)}
;
}
```
## 常见开发场景
### 添加新页面
1. 在 `src/app/` 下创建文件夹和 `page.tsx`
2. 使用 shadcn 组件构建 UI
3. 根据需要添加 `layout.tsx` 和 `loading.tsx`
### 创建业务组件
1. 在 `src/components/` 下创建组件文件(非 UI 组件)
2. 优先组合使用 `src/components/ui/` 中的基础组件
3. 使用 TypeScript 定义 Props 类型
### 添加全局状态
推荐使用 React Context 或 Zustand:
```tsx
// src/lib/store.ts
import { create } from 'zustand';
interface Store {
count: number;
increment: () => void;
}
export const useStore = create((set) => ({
count: 0,
increment: () => set((state) => ({ count: state.count + 1 })),
}));
```
### 集成数据库
推荐使用 Prisma 或 Drizzle ORM,在 `src/lib/db.ts` 中配置。
## 技术栈
- **框架**: Next.js 16.1.1 (App Router)
- **UI 组件**: shadcn/ui (基于 Radix UI)
- **样式**: Tailwind CSS v4
- **表单**: React Hook Form + Zod
- **图标**: Lucide React
- **字体**: Geist Sans & Geist Mono
- **包管理器**: pnpm 9+
- **TypeScript**: 5.x
## 参考文档
- [Next.js 官方文档](https://nextjs.org/docs)
- [shadcn/ui 组件文档](https://ui.shadcn.com)
- [Tailwind CSS 文档](https://tailwindcss.com/docs)
- [React Hook Form](https://react-hook-form.com)
## 重要提示
1. **必须使用 pnpm** 作为包管理器
2. **优先使用 shadcn/ui 组件** 而不是从零开发基础组件
3. **遵循 Next.js App Router 规范**,正确区分服务端/客户端组件
4. **使用 TypeScript** 进行类型安全开发
5. **使用 `@/` 路径别名** 导入模块(已配置)