- 架构层:ViewModel/ObservableObject、Service/Repository、网络层 APIClient/APIEndpoint/APIError - 设计系统:Color(light:dark:) 自适应 28 色 Token、ColorSchemeManager 深浅色切换 - 全页面:AI 对话/反馈/回忆/薄弱点、知识库 CRUD、学习工作台、复习计划、学习分析、个人中心/设置 - 登录与引导:Sign in with Apple、AppSession 状态管理、引导流程、演示模式 - 本地持久化:FileCache + PersistenceController(学习任务/复习任务/学习记录) - 本地化:zh-Hans Localizable.strings ~120 条、ZXStrings 程序化引用、LanguageManager - 组件库:ZXTabBar/ZXBackHeader/ZXSTaskRow/ZXChartView/ZXTypingIndicator 等 22 个共享组件 - 等待名单:WaitlistView 邮箱收集表单 - 动效:ZXTypingIndicator AI 打字动画、ZXShimmerModifier 骨架屏 - 测试:StudyHomeViewModel/AIChatViewModel/ReviewPlanViewModel/FileCache 共 28 条 - Dynamic Type 支持 + 范围限制 Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
9.4 KiB
9.4 KiB
个人开发者创业 v0.1 — iOS 相关需求整理
来源:
startup-plan/个人开发者创业 v0.1/各文档 整理时间:2026-05-10
本文档从 v0.1 创业计划中提取所有与 iOS 客户端直接相关的内容,作为 iOS 开发的参考基线。
一、产品定位(来源:0-项目总纲/项目总纲.md)
- 产品长期方向:AI 驱动的系统化学习产品(知识库 + 笔记 + AI 学习教练 + 复习计划)
- 当前只做三件事:确定方向 → 做 14 天验证 Demo → 找第一批真实反馈
- 平台策略:只做 iPhone,不做 Android/iPad/Mac/Web 学习端
- 不做:完整平台、泛学习大而全、复杂后端、支付
三个候选方向
- 公考申论 AI 学习教练
- AI 工具学习知识库
- 程序员/前端面试学习助手
二、第一版产品形态(来源:2-Demo与MVP/Demo与MVP.md)
iPhone App + 官网基础页面 + 最小后端 + AI API
MVP 核心学习闭环
注册/登录 → 选择学习方向 → 进入学习路径 → 阅读知识内容
→ 主动回忆/写笔记/写答案 → AI 分析 → 生成学习状态
→ 给出复习和下一步建议 → 进入下一次学习
第一版页面列表(计划 14 页)
| 优先级 | 页面 | 当前 iOS 实现 |
|---|---|---|
| P0 | 登录页 | LoginPage ✅ |
| P0 | 学习方向选择页 | GoalSetupPage ✅ (部分) |
| P0 | 学习路径页 | LibraryHomeView + LibraryDetailPage ✅ |
| P0 | 今日学习任务页 | StudyHomeView ✅ |
| P0 | 内容阅读页 | KnowledgeDetailPage ✅ |
| P0 | 主动回忆/笔记输入页 | DailyThinkingPage + RecallTestPage ✅ |
| P0 | AI 分析结果页 | AIFeedbackPage ✅ |
| P0 | AI 对话页 | AIChatPage ✅ |
| P0 | 复习计划页 | 未独立实现 ⚠️ (部分在 StudyHomeView) |
| P1 | 学习进度页 | AnalysisHomeView ✅ |
| P1 | 设置页 | ProfileView ✅ |
| P1 | 反馈页 | 未实现 ❌ |
| P1 | 启动页/欢迎页 | SplashPage + WelcomePage ✅ |
| P1 | 语言与基础偏好页 | 未实现 ❌ |
底部 Tab 设计(计划)
学习 | 知识库 | AI助手 | 我的
当前 iOS 实现为 5 个 Tab:AI | 知识库 | 学习 | 分析 | 我的(多了"分析"Tab,将计划的 AI 助手拆分为独立的分析页)
三、账号体系(来源:2-Demo与MVP/Demo与MVP.md)
- 第一版登录方式:Sign in with Apple
- 暂不做:微信登录、手机号登录、邮箱密码登录、Google 登录
⚠️ 当前 iOS
LoginPage包含了手机号/邮箱登录 + 微信/Apple 登录 UI,与计划"A Sign in with Apple"的要求不完全一致。计划强调极简,实际 UI 做了更多登录方式入口。
用户身份模型(计划)
User
├── id
├── appleUserId
├── displayName
├── email
├── preferredLanguage
├── createdAt
├── lastLoginAt
└── status
四、知识库设计(来源:2-Demo与MVP/Demo与MVP.md)
数据结构
KnowledgeBase → LearningPath → Module → Lesson
├── 正文内容
├── 学习目标
├── 重点概念
├── 主动回忆问题
├── 练习输入
└── AI 分析规则
第一版内容范围
只做一个小路径,例如"AI 工具入门 7 天路径",而不是大而全的知识库市场。
五、AI 能力需求(来源:2-Demo与MVP/Demo与MVP.md)
AI 三大核心职责
- 分析用户输入
- 判断用户当前学习状态
- 给出下一步学习建议
AI 分析维度
理解程度、要点覆盖、逻辑结构、表达清晰度、错误理解、遗漏内容、下一步建议
AI 输出结构(计划 JSON Schema)
{
"masteryScore": 3,
"understandingLevel": "基本理解",
"summary": "用户能说出核心意思,但要点不够完整。",
"strengths": ["能识别主要问题", "表达比较清楚"],
"weakPoints": ["遗漏关键要点", "逻辑层次不够清晰"],
"suggestions": ["补充材料中的第二个要点", "回答时先概括问题,再展开原因"],
"reviewNeeded": true,
"nextAction": "建议明天复习本节,并重新回答主动回忆问题。"
}
掌握度评分(0-5)
0 = 没有作答/无法判断
1 = 基本没理解
2 = 理解较弱
3 = 基本理解
4 = 理解较好
5 = 掌握很好
AI 对话页定位
只能围绕当前知识库和学习内容,不能做泛聊天。快捷问题预设:
- 帮我解释这一节
- 用更简单的话讲
- 给我举个例子
- 我哪里理解错了
- 帮我总结重点
- 生成一个复习问题
六、学习状态模型(来源:2-Demo与MVP/Demo与MVP.md)
用户学习画像
UserLearningProfile
├── userId
├── currentKnowledgeBaseId
├── currentPathId
├── currentLessonId
├── overallLevel
├── weakPoints
├── strengths
├── recentMistakes
├── reviewQueue
├── learningStreak
└── updatedAt
单次学习记录
LearningSession
├── id
├── userId
├── lessonId
├── startedAt
├── endedAt
├── userInput
├── aiAnalysis
├── masteryScore
├── weakPoints
├── nextSuggestion
└── reviewAt
复习任务
ReviewTask
├── id
├── userId
├── lessonId
├── sourceSessionId
├── reviewType
├── scheduledAt
├── completedAt
└── status
七、UI 设计原则(来源:2-Demo与MVP/Demo与MVP.md)
安静、清晰、克制、学习感、低干扰、Apple原生感、卡片式结构、适合长时间阅读
- 不做花哨视觉
- 不做复杂动画
- 不做社交信息流
- 不做游戏化过重设计
- 优先保证阅读体验
- 优先保证学习任务清晰
- 优先保证 AI 分析结果可理解
八、技术选型(来源:3-官网与技术基础/官网与技术基础.md)
| 项目 | 计划选型 | 当前实现 |
|---|---|---|
| UI 框架 | SwiftUI | SwiftUI ✅ |
| 架构模式 | MVVM + Service + Repository | 无分层(View 内聚)⚠️ |
| 设计规范 | Apple HIG | 深色主题 + 自定义 DesignTokens ✅ |
| 动效策略 | 轻量、有意义、服务学习体验 | 最小动效(仅基础过渡)⚠️ |
| 多语言 | 预留架构,中文默认 | 未实现 ❌ |
| 部署 | 4 核 4G 轻量云 + Nginx + Docker | 未接入 ❌ |
目录结构(计划 vs 实际)
计划定义了完整的分层目录(App/Core/Features/Shared/Resources),当前实现仅有 Features 和 DesignSystem,缺少 Network、Auth、Storage、Localization、ViewModel、Model 等层。
第一版 iOS 不做(来自计划)
- 复杂动画系统
- iPad 专门布局 / Mac Catalyst / Watch App / Widget
- 离线完整知识库
- 复杂搜索
- 文件导入
- 推送通知
- 支付订阅
- 复杂自定义控件
九、数据实体汇总(来源:2-Demo与MVP/Demo与MVP.md)
User
KnowledgeBase
LearningPath
Lesson
LearningSession
AIAnalysis
ReviewTask
Feedback
WaitlistEntry
十、核心 API 接口(来源:3-官网与技术基础/官网与技术基础.md)
POST /ai/analyze-learning-input
分析用户学习输入,返回掌握度评估。
POST /ai/chat
AI 对话接口,限于当前知识库上下文。
后端模块(P0)
Auth → User → Knowledge → Learning → AI → Review → Feedback → Waitlist
十一、成功标准(来源:2-Demo与MVP/Demo与MVP.md)
产品可用标准
- 用户能登录
- 用户能选择学习路径
- 用户能完成一节学习
- 用户能输入内容
- AI 能返回分析
- 系统能生成复习建议
- 用户知道下一步该干什么
验证成功标准
- 至少 10 个用户愿意试用
- 至少 3 个用户完整走完学习闭环
- 至少 3 条有效反馈
- 至少 1 个用户表示愿意继续用
- 至少 1 个用户表示未来愿意付费
十二、暂缓事项(来源:99-暂缓事项/暂缓事项.md)
以下为 v0.1 明确不做、后续解冻的事项:
| 类别 | 暂缓内容 | 解冻条件 |
|---|---|---|
| 商业化 | Apple IAP、订阅、免费试用 | TestFlight 有真实用户 + 有人愿意付费 |
| 运营 | 社群、客服机器人、打卡活动 | 10+ 内测用户持续反馈 |
| 数据 | 完整埋点、留存分析、付费转化 | App Store MVP 准备上线 |
| 合规 | 公司注册、微信/支付宝、备案 | Apple 端稳定收入 |
| 多端 | iPad、Mac、Android、Web | iPhone 核心稳定 + 用户多端需求 |
十三、当前 iOS 实现与计划的差距
| 维度 | 计划要求 | 当前状态 | 差距 |
|---|---|---|---|
| 登录 | Sign in with Apple | 多种登录 UI | 需简化或实现 Apple 登录 |
| 架构 | MVVM + Service | View 内聚 | 需重构分层 |
| 多语言 | 架构预留 | 未实现 | 需添加本地化 |
| 后端对接 | REST API | 无 | 需接入 |
| AI 集成 | 真实 AI 分析 | 静态 Mock | 需接入 AI API |
| 数据持久化 | 本地缓存 + Keychain | 无 | 需实现 |
| Tab 设计 | 4 个 Tab | 5 个 Tab | 多了"分析"Tab |
| 反馈页 | P1 优先级 | 未实现 | 需添加 |
| 复习计划页 | P0 优先级 | 部分实现 | 需独立设计 |