# # Story 016.010: 创建使用示例和文档 ## Status Draft ## Story **作为** 小程序开发者, **我想要** 完整的使用示例和 API 文档, **以便** 快速上手使用 mini-charts 包,理解各种图表组件的配置选项和使用方法。 ## 背景 mini-charts 包已完成核心库模块化搬迁(故事 016.001-016.008)和 React 图表组件封装(故事 016.009),现在需要提供完整的文档和示例,帮助开发者快速理解和使用这个图表库。 **前置故事完成状态**: - ✅ 故事 016.001-016.008: u-charts 核心库已完成模块化搬迁和类型定义 - ✅ 故事 016.009: React 图表组件封装完成,包括 BaseChart 和 5 种图表组件 - ✅ 所有组件类型定义完整,类型检查通过 - ✅ 包可以成功构建,自动生成 .d.ts 声明文件 **参考资料**: - `docs/小程序图表库示例/使用示例.md` - 原始类组件使用示例 - `docs/prd/epic-016-mini-charts-package.md` - Epic 016 完整定义 ## 前置故事完成状态 **故事 016.001**: ✅ 已完成 - 创建 mini-charts 包基础结构 **故事 016.002**: ✅ 已完成 - 模块化 config 和 utils **故事 016.003**: ✅ 已完成 - 模块化 data-processing 函数 **故事 016.004**: ✅ 已完成 - 模块化 charts-data 函数 **故事 016.005**: ✅ 已完成 - 模块化 renderers 函数 **故事 016.006**: ✅ 已完成 - 搬迁核心类并完成模块化 **故事 016.007**: ✅ 已完成 - 搬迁遗漏的辅助函数 **故事 016.008**: ✅ 已完成 - 搬迁核心绘制函数完成模块化 **故事 016.009**: ✅ 已完成 - 创建 React 图表组件封装 ## Acceptance Criteria 1. 创建 examples 目录,包含至少 3 个示例(柱状图、折线图、K线图) 2. 创建完整的 README.md,包含所有必需章节(简介、安装、快速开始、API 文档、配置选项、常见问题) 3. API 文档详细,覆盖所有公共接口(组件 Props、配置选项) 4. 配置选项说明清晰,包含示例代码 5. 更新原使用示例文档(`docs/小程序图表库示例/使用示例.md`),指向新包的使用方式 6. 示例代码使用现代 React 函数式组件,与封装的组件一致 7. 文档和示例类型检查通过(`pnpm typecheck`) ## Tasks / Subtasks - [ ] Task 1: 创建 examples 目录和基础示例 (AC: 1, 6) - [ ] 1.1 创建 `examples/` 目录 - [ ] 1.2 创建 `examples/BasicColumnChart.tsx` - 基础柱状图示例 - [ ] 1.3 创建 `examples/BasicLineChart.tsx` - 基础折线图示例(支持拖拽) - [ ] 1.4 创建 `examples/BasicCandleChart.tsx` - 基础K线图示例 - [ ] 1.5 创建 `examples/PieChartExample.tsx` - 饼图示例 - [ ] 1.6 创建 `examples/RadarChartExample.tsx` - 雷达图示例 - [ ] 1.7 创建 `examples/index.ts` - 统一导出所有示例 - [ ] 1.8 所有示例使用 React 函数式组件,使用封装的图表组件 - [ ] Task 2: 创建 README.md 主文档 (AC: 2, 3, 4) - [ ] 2.1 创建 `mini-ui-packages/mini-charts/README.md` - [ ] 2.2 编写「简介」章节 - 包特性、支持的图表类型 - [ ] 2.3 编写「安装」章节 - pnpm 安装命令 - [ ] 2.4 编写「快速开始」章节 - 最小化示例代码 - [ ] 2.5 编写「组件 API」章节 - 所有图表组件的 Props 接口说明 - [ ] 2.6 编写「配置选项」章节 - uCharts 配置选项详解 - [ ] 2.7 编写「常见问题」章节 - FAQ - [ ] 2.8 编写「迁移指南」章节 - 从原始 u-charts 迁移到新组件的方式 - [ ] Task 3: 创建 API 文档 (AC: 3, 4) - [ ] 3.1 创建 `docs/api/` 目录 - [ ] 3.2 创建 `docs/api/BaseChart.md` - BaseChart 组件 API - [ ] 3.3 创建 `docs/api/ColumnChart.md` - ColumnChart 组件 API - [ ] 3.4 创建 `docs/api/LineChart.md` - LineChart 组件 API - [ ] 3.5 创建 `docs/api/CandleChart.md` - CandleChart 组件 API - [ ] 3.6 创建 `docs/api/PieChart.md` - PieChart 组件 API - [ ] 3.7 创建 `docs/api/RadarChart.md` - RadarChart 组件 API - [ ] 3.8 每个 API 文档包含: Props 接口定义、类型说明、示例代码 - [ ] Task 4: 创建高级示例 (AC: 1, 6) - [ ] 4.1 创建 `examples/MixedChartExample.tsx` - 混合图表示例(如柱状图+折线图) - [ ] 4.2 创建 `examples/CustomConfigExample.tsx` - 自定义配置示例(颜色、字体、动画等) - [ ] 4.3 创建 `examples/ResponsiveChartExample.tsx` - 响应式图表示例 - [ ] 4.4 创建 `examples/DataUpdateExample.tsx` - 数据动态更新示例 - [ ] Task 5: 更新 package.json 导出配置 (AC: 2) - [ ] 5.1 更新 `mini-ui-packages/mini-charts/package.json` 的 exports 字段 - [ ] 5.2 添加 examples 路径导出配置 - [ ] 5.3 验证导出配置正确 - [ ] Task 6: 更新原使用示例文档 (AC: 5) - [ ] 6.1 更新 `docs/小程序图表库示例/使用示例.md` - [ ] 6.2 在文档顶部添加「新版本使用方式」章节 - [ ] 6.3 提供新版本组件的使用示例代码 - [ ] 6.4 保留原始示例作为参考,标记为「旧版本」 - [ ] Task 7: 验证文档和示例 (AC: 7) - [ ] 7.1 运行类型检查验证示例代码类型正确(`pnpm typecheck`) - [ ] 7.2 验证所有文档链接正确 - [ ] 7.3 验证示例代码可以复制粘贴使用 - [ ] 7.4 验证 README.md 格式规范 ## Dev Notes ### 前置故事见解 **故事 016.009 完成状态总结**: - ✅ BaseChart 基础组件创建完成,封装 Canvas 逻辑 - ✅ 5 种图表组件实现完成: ColumnChart、LineChart、CandleChart、PieChart、RadarChart - ✅ 所有组件支持 Props 配置,类型定义完整 - ✅ 组件支持触摸事件处理(tooltip 显示) - ✅ 组件支持响应式尺寸计算和像素比适配 - ✅ 类型检查通过(`pnpm typecheck`) - ✅ 构建成功(`pnpm build`),生成完整的 .d.ts 声明文件 **可用的组件 API**: ```typescript // src/index.ts 导出的组件 export { BaseChart } from './components/BaseChart'; export { ColumnChart } from './components/ColumnChart'; export { LineChart } from './components/LineChart'; export { CandleChart } from './components/CandleChart'; export { PieChart } from './components/PieChart'; export { RadarChart } from './components/RadarChart'; // 导出的类型定义 export type { BaseChartProps } from './components/BaseChart'; export type { ColumnChartProps } from './components/ColumnChart'; export type { LineChartProps } from './components/LineChart'; export type { CandleChartProps } from './components/CandleChart'; export type { PieChartProps } from './components/PieChart'; export type { RadarChartProps } from './components/RadarChart'; ``` ### 项目结构指南 **来源**: [source-tree.md](../../architecture/source-tree.md) ``` mini-ui-packages/ └── mini-charts/ # mini-charts 包 ├── src/ │ ├── index.ts # 主入口文件 │ ├── components/ # React 图表组件 [已完成] │ └── lib/ # u-charts 核心库 [已完成] ├── examples/ # [本故事创建] 使用示例 │ ├── BasicColumnChart.tsx # 基础柱状图示例 │ ├── BasicLineChart.tsx # 基础折线图示例 │ ├── BasicCandleChart.tsx # 基础K线图示例 │ ├── PieChartExample.tsx # 饼图示例 │ ├── RadarChartExample.tsx # 雷达图示例 │ ├── MixedChartExample.tsx # 混合图表示例 │ ├── CustomConfigExample.tsx # 自定义配置示例 │ ├── ResponsiveChartExample.tsx # 响应式示例 │ ├── DataUpdateExample.tsx # 数据更新示例 │ └── index.ts # 示例导出 ├── docs/ # [本故事创建] API 文档 │ └── api/ │ ├── BaseChart.md # BaseChart API 文档 │ ├── ColumnChart.md # ColumnChart API 文档 │ ├── LineChart.md # LineChart API 文档 │ ├── CandleChart.md # CandleChart API 文档 │ ├── PieChart.md # PieChart API 文档 │ └── RadarChart.md # RadarChart API 文档 ├── README.md # [本故事创建] 主文档 ├── package.json └── tsconfig.json ``` ### 组件使用示例(来自故事 016.009) **来源**: [016.009 React Chart Components](016.009.react-chart-components.md) #### 柱状图组件使用 ```typescript import React from 'react'; import { ColumnChart } from '@d8d/mini-charts'; const MyComponent = () => { const data = { categories: ['2018', '2019', '2020', '2021', '2022', '2023'], series: [{ name: '目标值', data: [35, 36, 31, 33, 13, 34] }, { name: '完成量', data: [18, 27, 21, 24, 6, 28] }] }; return ( ); }; ``` #### 折线图组件使用 ```typescript import React from 'react'; import { LineChart } from '@d8d/mini-charts'; const MyComponent = () => { const data = { categories: ['2018', '2019', '2020', '2021', '2022', '2023'], series: [{ name: '成交量A', data: [35, 36, 31, 33, 13, 34] }] }; return ( ); }; ``` #### K线图组件使用 ```typescript import React from 'react'; import { CandleChart } from '@d8d/mini-charts'; const MyComponent = () => { const data = { categories: ['2018', '2019', '2020', '2021', '2022', '2023'], series: [{ name: '上证指数', data: [ [2320.26, 2320.26, 2280.12, 2307.89], [2325.61, 2332.45, 2305.86, 2315.23] ] }] }; return ( ); }; ``` ### Props 接口定义(来自故事 016.009) **来源**: [016.009 Dev Notes](016.009.react-chart-components.md#dev-notes) #### BaseChartProps ```typescript export interface BaseChartProps { canvasId: string; // Canvas ID width?: number; // 图表宽度(可选) height?: number; // 图表高度(可选) pixelRatio?: number; // 像素比(可选,默认根据平台自动计算) categories: string[]; // X轴分类数据 series: any[]; // 系列数据 config?: Record; // uCharts 配置对象(可选) onTouchStart?: (e: any) => void; onTouchMove?: (e: any) => void; onTouchEnd?: (e: any) => void; } ``` #### ColumnChartProps ```typescript export interface ColumnChartProps extends Omit { canvasId?: string; // Canvas ID(可选,默认自动生成) data?: { // 图表数据(可选) categories: string[]; series: any[]; }; dataLabel?: boolean; // 是否显示数据标签(默认 true) columnType?: 'group' | 'stack'; // 柱状图类型(默认 'group') config?: Record; // 额外配置(可选) } ``` #### LineChartProps ```typescript export interface LineChartProps extends Omit { canvasId?: string; // Canvas ID(可选,默认自动生成) data?: { // 图表数据(可选) categories: string[]; series: any[]; }; dataPointShape?: boolean; // 是否显示数据点形状(默认 true) enableScroll?: boolean; // 是否启用滚动(默认 false) config?: Record; // 额外配置(可选) } ``` #### CandleChartProps ```typescript export interface CandleChartProps extends Omit { canvasId?: string; // Canvas ID(可选,默认自动生成) data?: { // 图表数据(可选) categories: string[]; series: any[]; }; enableScroll?: boolean; // 是否启用滚动(默认 false) showMA?: number[]; // 移动平均线周期数组(如 [5, 10, 30]) config?: Record; // 额外配置(可选) } ``` #### PieChartProps ```typescript export interface PieChartProps extends Omit { canvasId?: string; // Canvas ID(可选,默认自动生成) data?: { // 图表数据(可选) categories: string[]; series: any[]; }; pieType?: 'pie' | 'ring'; // 饼图类型(默认 'pie') dataLabel?: boolean; // 是否显示数据标签(默认 true) config?: Record; // 额外配置(可选) } ``` #### RadarChartProps ```typescript export interface RadarChartProps extends Omit { canvasId?: string; // Canvas ID(可选,默认自动生成) data?: { // 图表数据(可选) categories: string[]; series: any[]; }; dataPointShape?: boolean; // 是否显示数据点形状(默认 true) config?: Record; // 额外配置(可选) } ``` ### 技术栈要求 **来源**: [mini-charts/package.json](../../mini-ui-packages/mini-charts/package.json) - **React**: 18.0.0(mini 包使用 React 18,不是 React 19) - **Taro**: 4.1.4(包括 @tarojs/components, @tarojs/react, @tarojs/taro) - **TypeScript**: 5.4.5 - **Node.js**: 20.18.3(运行时环境) - **包管理器**: pnpm workspace ### TypeScript 配置规范 **来源**: [ui-package-standards.md](../../architecture/ui-package-standards.md#typescript配置) ```json { "compilerOptions": { "target": "ES2020", "lib": ["DOM", "DOM.Iterable", "ES2020"], "module": "ESNext", "strict": true, "noUnusedLocals": true, "noUnusedParameters": true, "noFallthroughCasesInSwitch": true } } ``` **本故事重要**: 示例代码必须满足 TypeScript 严格模式,类型检查通过。 ### 文档编写规范 **README.md 结构要求**: ```markdown # @d8d/mini-charts ## 简介 - 包特性描述 - 支持的图表类型 - 技术特性 ## 安装 \`\`\`bash pnpm add @d8d/mini-charts \`\`\` ## 快速开始 \`\`\`typescript import { ColumnChart } from '@d8d/mini-charts'; // 最小化示例 \`\`\` ## 组件 API - BaseChart - ColumnChart - LineChart - CandleChart - PieChart - RadarChart ## 配置选项 - 通用配置 - 各图表类型专属配置 ## 常见问题 - FAQ列表 ## 迁移指南 - 从原始 u-charts 迁移 ## 相关链接 - u-charts 官方文档 ``` **API 文档结构要求**: ```markdown # [ComponentName] API ## 概述 组件简要描述 ## Props 接口 \`\`\`typescript export interface ComponentNameProps { // Props 定义 } \`\`\` ## Props 说明 | Prop | 类型 | 默认值 | 说明 | |------|------|--------|------| | ... | ... | ... | ... | ## 示例代码 \`\`\`typescript // 完整示例 \`\`\` ## 相关文档 - 链接到其他相关组件 ``` ### package.json 导出配置规范 **来源**: [ui-package-standards.md](../../architecture/ui-package-standards.md#packagejson配置) ```json { "exports": { ".": { "types": "./src/index.ts", "import": "./src/index.ts", "require": "./src/index.ts" }, "./components": { "types": "./src/components/index.ts", "import": "./src/components/index.ts", "require": "./src/components/index.ts" } } } ``` **本故事**: 需要添加 examples 导出配置。 ### 编码标准 **来源**: [coding-standards.md](../../architecture/coding-standards.md) - **代码风格**: TypeScript 严格模式,一致的缩进和命名 - **示例代码**: 使用 React 函数式组件,与封装的组件一致 - **注释规范**: 为复杂配置添加中文注释说明 - **文档格式**: 使用 Markdown 格式,代码块指定语言类型 ### 测试要求 **来源**: [testing-strategy.md](../../architecture/testing-strategy.md) **本故事**: 文档和示例代码需要通过类型检查,验证其正确性。 ```bash # 类型检查示例代码 pnpm typecheck ``` ### 原始使用示例分析 **来源**: [docs/小程序图表库示例/使用示例.md](../../小程序图表库示例/使用示例.md) **原始使用方式(类组件)**: - 使用 `Component` 类组件 - 手动管理 Canvas 上下文 (`Taro.createCanvasContext`) - 手动计算响应式尺寸 - 手动处理触摸事件 - 使用原始 uCharts 类 **新使用方式(函数式组件)**: - 使用现代 React 函数式组件 - 使用封装的图表组件,无需手动管理 Canvas - 组件内部自动处理响应式尺寸 - 组件内部自动处理触摸事件 - 类型安全的 Props 接口 ### 文件位置规范 **新增文件位置**: - 示例目录: `mini-ui-packages/mini-charts/examples/` - API 文档: `mini-ui-packages/mini-charts/docs/api/` - 主文档: `mini-ui-packages/mini-charts/README.md` **修改文件**: - `mini-ui-packages/mini-charts/package.json` - 添加 examples 导出配置 - `docs/小程序图表库示例/使用示例.md` - 添加新版本使用方式 ### 技术约束 1. **React版本**: 必须使用 React 18 函数式组件 2. **Taro版本**: 使用 @tarojs/taro 4.1.4 API 3. **类型安全**: 示例代码必须通过类型检查 4. **文档格式**: 使用 Markdown 格式 5. **代码示例**: 所有示例代码必须可以复制粘贴使用 6. **中文文档**: 所有文档使用中文编写 ### 验证标准 完成本故事后,应该满足: 1. ✅ `examples/` 目录下至少有 3 个基础示例和 3 个高级示例 2. ✅ `README.md` 文档完整,包含所有必需章节 3. ✅ `docs/api/` 目录下每个组件都有 API 文档 4. ✅ API 文档详细,覆盖所有公共接口 5. ✅ 配置选项说明清晰,包含示例 6. ✅ 原使用示例文档已更新,添加新版本使用方式 7. ✅ 运行 `pnpm typecheck` 无类型错误 8. ✅ 示例代码可以直接复制使用 ### 不包含在本故事中的工作 以下工作**不在**本故事范围内: - ❌ 创建完整的测试套件(故事 016.011) - ❌ 在实际小程序页面中集成使用示例 - ❌ 创建在线文档网站 - ❌ 性能优化和基准测试 ## Change Log | Date | Version | Description | Author | |------|---------|-------------|--------| | 2025-12-24 | 1.0 | 创建故事文档 | Bob (Scrum Master) | ## Dev Agent Record *此部分由开发代理在实施过程中填写* ### Agent Model Used 待填写 ### Debug Log References 待填写 ### Completion Notes List 待填写 ### File List 待填写 ## QA Results *此部分由 QA 代理在审查完成后填写*