为备孕女性量身定制的全面体检方案网站,涵盖医院推荐、体检套餐、项目清单、免费政策和AI智能助手。
在线访问: https://health.rxcloud.group
- 智能年龄推荐 — 根据年龄(25-40岁)自动推荐适合的体检套餐
- AI备孕顾问 — 浮动聊天助手,解答医学术语、体检项目、备孕准备等问题
- 上海8家医院推荐 — 专科、综合、平价三类医院详情对比
- 30+体检项目清单 — 可勾选的互动式检查项目列表
- 免费孕前检查政策 — 上海免费政策申请流程和条件详解
- 医学术语词典 — 20+常见术语(AMH、TORCH、性激素六项等)悬浮解释
![]() |
![]() |
|---|---|
| 三档套餐智能推荐 | AI备孕顾问聊天 |
| 层级 | 技术 |
|---|---|
| 前端框架 | React 19 + TypeScript |
| 构建工具 | Vite 7 |
| UI组件库 | shadcn/ui (40+ 组件) + Tailwind CSS v3 |
| 后端服务 | Supabase Edge Functions (Deno) |
| 数据库 | Supabase PostgreSQL |
| 部署 | Vercel (前端) + Supabase (后端) |
| AI模型 | OpenAI GPT-3.5-turbo (可配置) |
单页滚动应用,由9个区块组件组成。全局状态仅 userAge 一个,从 HeroSection 的年龄选择器传递到需要个性化推荐的子组件。
支持两种运行模式:
- 演示模式(默认)— 本地关键词匹配,无需后端,7个预设话题的即时回复
- API模式 — 通过 Supabase Edge Function 调用 OpenAI,对话历史持久化存储
AI Agent 采用四层架构设计:
| 层级 | 职责 | 核心组件 |
|---|---|---|
| 表现层 | UI交互与渲染 | AIAssistant.tsx(浮窗聊天)、MedicalTerm.tsx(术语悬浮提示)、AgeSelector.tsx |
| Agent服务层 | 对话管理与路由 | AIService 单例类、Mode Router(演示/API切换)、Conversation History Manager |
| 后端服务层 | AI调用与持久化 | Supabase Edge Function health-chat(Deno运行时)、Supabase Client |
| 数据与AI层 | 存储与模型推理 | PostgreSQL(health_conversations + health_messages)、OpenAI GPT-3.5-turbo |
消息处理管线的关键步骤:
- 用户输入 — AIAssistant.tsx 捕获输入,设置加载状态,更新 React 消息列表
- 消息路由 — AIService.sendMessage() 根据
demoMode配置分流:- Demo路径:800ms模拟延迟 →
getDemoResponse()关键词匹配引擎(7条规则,覆盖AMH/TORCH/性激素/时间/准备/免费政策/叶酸) - API路径:Supabase Edge Function → 加载DB对话历史 → 构建
[system_prompt, ...history, user_message]→ OpenAI API → 存储消息 → 返回
- Demo路径:800ms模拟延迟 →
- 后处理 — 创建助手消息对象,推入 conversationHistory,滑动窗口保留最近20条
- UI更新 — 添加到 React 状态,关闭加载指示器,自动滚动到底部
| 知识组件 | 内容 | 用途 |
|---|---|---|
SYSTEM_PROMPT |
角色定义(备孕健康顾问)、能力范围、回答原则、地域限定(上海) | Edge Function 构建 messages 数组的首条消息 |
MEDICAL_TERMS |
20+医学术语释义(AMH、TORCH、TCT、HPV、性激素六项等) | MedicalTerm.tsx 悬浮提示 + AI回复参考 |
AGE_GROUPS |
4个年龄段模型(25-28/29-32/33-35/36-40),含AMH参考范围、关注重点、推荐套餐 | AgeSelector 个性化推荐 + AI年龄建议 |
DEMO_RESPONSES |
7个预设话题的完整回复(含格式化markdown) | 演示模式离线回复 |
本项目采用 对话式 Agent 模式(Conversational Agent Pattern),核心设计要素:
- Prompt Engineering — 通过 SYSTEM_PROMPT 定义 Agent 人格、能力边界和回答风格
- Context Injection — 用户年龄(userAge)作为会话级上下文动态注入
- Conversation Memory — 滑动窗口策略,客户端保留最近20条,服务端全量持久化
- Knowledge Retrieval — 静态词典查询(非向量检索),适用于有限领域知识
- Graceful Degradation — 演示模式作为离线降级方案,无后端依赖即可运行
| 维度 | 本项目(简单对话Agent) | RAG模式 | ReAct模式 | Function Calling |
|---|---|---|---|---|
| 知识检索 | 关键词匹配(if/else) | 向量数据库语义搜索 | 推理驱动的检索 | LLM自主决策 |
| 推理能力 | 单次LLM调用 | 检索增强生成 | 推理→执行→观察循环 | 工具链式调用 |
| 外部工具 | 无 | 向量DB | 多种工具 | API/DB/搜索等 |
| 记忆管理 | 滑动窗口20条 | 向量化长期记忆 | 工作记忆+长期记忆 | 上下文窗口 |
| 适用场景 | 有限领域FAQ | 大规模文档问答 | 复杂多步推理 | 需要执行操作 |
# 克隆并安装
git clone <repo-url>
cd health-agent/app
npm install
# 启动开发服务器
npm run dev默认以演示模式运行,无需任何后端配置即可体验全部功能。
- 在 Supabase 控制台设置 Edge Function Secret:
OPENAI_API_KEY - 配置环境变量:
VITE_SUPABASE_URL=your_supabase_url
VITE_SUPABASE_ANON_KEY=your_anon_key
VITE_DEMO_MODE=falsehealth-agent/
├── app/ # 前端应用 (Vite项目根目录)
│ ├── src/
│ │ ├── components/
│ │ │ ├── ui/ # shadcn/ui 组件库 (40+)
│ │ │ ├── AIAssistant.tsx # AI聊天助手浮窗
│ │ │ ├── AgeSelector.tsx # 年龄选择器
│ │ │ └── MedicalTerm.tsx # 医学术语悬浮解释
│ │ ├── sections/
│ │ │ ├── Navigation.tsx # 顶部导航栏
│ │ │ ├── HeroSection.tsx # 英雄区 + 年龄选择
│ │ │ ├── PackageSection.tsx# 体检套餐推荐 (3档)
│ │ │ ├── HospitalSection.tsx# 医院推荐 (8家)
│ │ │ ├── ChecklistSection.tsx# 体检项目清单
│ │ │ ├── PolicySection.tsx # 免费政策指南
│ │ │ ├── GuideSection.tsx # 备孕指南
│ │ │ ├── CTASection.tsx # 行动号召
│ │ │ └── Footer.tsx # 页脚
│ │ ├── services/
│ │ │ ├── aiConfig.ts # AI配置 + 医学术语库 + 年龄段数据
│ │ │ ├── aiService.ts # AI服务层 (演示/API双模式)
│ │ │ └── supabase.ts # Supabase客户端初始化
│ │ ├── App.tsx # 根组件
│ │ └── main.tsx # 入口文件
│ ├── vercel.json # Vercel部署配置
│ └── package.json
├── docs/
│ └── images/ # 架构图示
├── screenshots/ # 网站截图
├── CLAUDE.md # 开发指南 (Claude Code)
└── README.md
| 套餐 | 价格范围 | 适合年龄 | 核心项目 |
|---|---|---|---|
| 基础版 | ¥1,500-2,500 | 25-28岁 | 血常规、尿常规、肝肾功能、妇科B超、白带常规、TORCH |
| 全面版 | ¥3,500-5,000 | 29-35岁 | 基础版 + AMH、性激素六项、甲状腺功能、TCT+HPV |
| 高端版 | ¥6,000-8,000 | 36岁以上 | 全面版 + 染色体核型、遗传病筛查、免疫抗体全套 |
| 医院 | 类型 | 特点 |
|---|---|---|
| 红房子医院 | 专科 | 妇产科国内顶尖 |
| 国妇婴 | 专科 | 生殖医学知名 |
| 一妇婴 | 专科 | 辅助生殖技术领先 |
| 仁济医院 | 综合 | 综合实力强 |
| 瑞金医院 | 综合 | 内分泌科权威 |
| 曙光医院 | 综合 | 中西医结合 |
| 第四人民医院 | 平价 | 性价比高 |
| 妇幼保健所 | 平价 | 免费检查定点 |
cd app
npm run dev # 启动开发服务器 (Vite HMR)
npm run build # 类型检查 + 生产构建
npm run lint # ESLint检查
npm run preview # 预览生产构建Vercel 自动部署,根目录设置为 app。需配置环境变量:
VITE_SUPABASE_URLVITE_SUPABASE_ANON_KEYVITE_DEMO_MODE=false
- Edge Function
health-chat处理AI对话 - PostgreSQL 存储对话历史 (
health_conversations,health_messages) - Dashboard -> Edge Functions -> Secrets 中设置
OPENAI_API_KEY
MIT








