4.2 KiB
4.2 KiB
AGENTS.md
本文件用于约束后续在本项目内协作的 AI/自动化代理行为。
项目目标
这是一个面向新手的微信小程序项目,目标是:
- 保持项目结构简单、易懂、易修改
- 使用
Taro + React + TypeScript作为核心技术栈 - 所有说明尽量使用中文
- 在保证可运行的前提下,减少复杂依赖
协作原则
- 修改代码前,先阅读现有文件,避免无意义重构。
- 优先做小步修改,保持项目始终可运行。
- 已确认使用
React + TypeScript,默认采用Taro作为微信小程序框架。 - 不要在
Taro之外再擅自引入新的大型框架或状态管理库,除非用户明确要求。 - 对新手不友好的实现方式,要同时补充解释性注释或文档。
- 涉及配置时,优先使用明确值,并在文档里写清楚用户需要修改的位置。
文件与代码规范
- 默认使用 UTF-8 编码。
- 页面、组件和配置命名尽量贴合
Taro与微信小程序习惯。 - 目录结构优先采用:
src/pages/放页面src/components/放可复用组件src/utils/放工具函数src/assets/放静态资源config/放 Taro 构建配置
- 默认使用 TypeScript 编写业务代码。
- 样式优先使用
.scss,但保持简单,避免过度抽象。 - 非必要不新增依赖,尤其避免在项目初期引入复杂状态管理、UI 大全家桶或重型工具链。
主题与组件约定
- 颜色统一收口到
src/styles/theme.scss,优先使用 CSS 变量,不要在页面和组件里散落写十六进制颜色值。 - 新增颜色时,先判断是否属于已有语义色:
- 品牌色
- 页面背景色
- 卡片背景色
- 文字主次色
- 警告色
- 危险色
- 如果某个颜色只在单个页面临时使用,也应优先评估是否值得提升为公共主题变量。
- 通用 UI 优先拆到
src/components/,尤其是以下类型:- 按钮
- 卡片
- 底部导航
- 列表项
- 状态块
- 如果一个结构或样式在两个及以上页面/区域重复出现,优先抽成可复用组件,而不是复制粘贴。
- 组件设计尽量保持“样式可配置、职责单一、命名清晰”,避免做过度复杂的大而全组件。
修改边界
- 可以新增或修改当前工作区内与本项目直接相关的文件。
- 如需删除文件,必须严格遵守工作区已有的删除安全规则。
- 不得擅自删除目录、批量删除文件、清空文件夹。
- 不得覆盖用户未明确要求替换的重要配置、密钥或证书文件。
AppID 与发布相关
- 不要伪造真实
AppID、密钥、证书、域名或后台接口地址。 - 涉及
AppID时,优先保留用户提供的真实值。 - 如果项目需要上线步骤说明,必须同步更新
README.md。
文档要求
- 每次新增关键功能、配置步骤或部署步骤时,优先同步更新
README.md。 - 文档写法以“零基础可照做”为标准,避免只写结论不写路径。
- 如果修改了 Taro 的开发、编译、预览或发布流程,必须更新
README.md中对应命令和目录说明。
原始设计色板参考
以下颜色可作为设计来源参考,但在代码中应优先映射为 src/styles/theme.scss 中的语义化变量,而不是直接把 color1、color2 这类名称搬进业务代码。
color1: '#45D989',
color2: "#00C1AA",
color3: "#333333",
color4: "#D3D3D3",
color6: "#FBF5D5",
color5: "#FFFFF006",
color7: "#00C1AA",
color8: "#FF9F66",
color9: "#FF7159",
color10: "#E60012",
color11: "#00C1AA",
color12: "#10CFF1",
color13: "#FF9F66",
color14: "#FF7159",
color15: "#F6F6F6",
color16: "#333333",
color17: "#FFFFFF",
color18: "#FFFFFF",
color19: "#FFFFFF",
color20: "#f7f8fa",
color21: "#eaeaea",
color22: "#eaeaea",
color25: "#FF7159",
color26: "#4AD8FA",
color27: "#f7f8fa",
color28: "#4E8408",
color29: "#79BC31",
color30: "#E55E92",
color31: "#FF1D25",
color32: "#7bbb33",
color33: "#fe15b8d",
color34: "#EE0000",
color38: "#E3E4E5",
color39: "#F3F5F6",
color40: "#333333"