一个高效使用cursor开发项目的方法,怎么让 AI 写的代码不跑题?
liuian 2025-09-04 11:58 25 浏览
最近又用 cursor 做了一个小应用,番茄时钟,用来管理自己的时间,提高效率。然后使用 cursor 开发的过程中。有了一些新的感悟。找到了一条可以让 Curosr不跑题的办法。
生成一份详细的项目资料。然后配置.cursorrule。让Cursor每次开发都参考资料,并自动更新。当然这些也都可以让 AI 帮你完成。下面的用 3 个步骤完成配置。
(ps:这是一个小项目,大型的项目可能效果暂不明确。但是对一个纯用 Cursor开发的小应用,效果嘎嘎香,再也不跑题了)
- 给项目写一份详细的资料
指令:
写一个详细的项目资料project-overview.md ,等我下次再提需求时,你可以参考快速熟悉项目。- 给项目配置一个 cursorrule
指令:
给项目配置一个 cursorrule- 让 rule 自动参考以及更新project-overview.md
指令
优化 rule,目的是每当我提问的时候,可以参考project-overview.md学习项目资料,当 AI 修改完成时 ,更新project-overview.md文件。以保持对话的连续性和稳定性。这样每次让 cursor修改功能时,他都会记录到文件中,可以保持AI 对话的连续性,也方便自己复盘。
附上我的cursor rule
{
"editor": {
"formatOnSave": true,
"tabSize": 2,
"insertSpaces": true,
"defaultFormatter": "prettier"
},
"typescript": {
"preferences": {
"quoteStyle": "single",
"importModuleSpecifierPreference": "relative",
"jsxAttributeCompletionStyle": "auto"
},
"suggest": {
"completeFunctionCalls": true,
"autoImports": true
},
"updateImportsOnFileMove": "always",
"format": {
"semicolons": true,
"singleQuote": true,
"trailingComma": "es5"
}
},
"javascript": {
"preferences": {
"quoteStyle": "single"
},
"format": {
"semicolons": true,
"singleQuote": true
}
},
"prettier": {
"singleQuote": true,
"semi": true,
"tabWidth": 2,
"trailingComma": "es5",
"printWidth": 100,
"bracketSpacing": true,
"jsxBracketSameLine": false,
"arrowParens": "avoid"
},
"eslint": {
"run": "onSave",
"packageManager": "npm"
},
"files": {
"exclude": [
"node_modules",
"dist",
"build",
"coverage",
".git",
"dev-dist"
],
"watcherExclude": {
"**/node_modules/**": true,
"**/dist/**": true,
"**/build/**": true
},
"associations": {
"*.tsx": "typescriptreact",
"*.ts": "typescript",
"*.jsx": "javascriptreact",
"*.js": "javascript"
}
},
"search": {
"exclude": {
"**/node_modules": true,
"**/dist": true,
"**/build": true
}
},
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true,
"source.organizeImports": true
},
"project": {
"name": "番茄时间管理应用",
"patterns": [
"**/*.ts",
"**/*.tsx",
"**/*.js",
"**/*.jsx",
"**/*.json",
"**/*.css",
"**/*.html"
],
"ignore": [
"node_modules",
"dist",
"build",
"coverage",
".git",
"dev-dist"
],
"documentation": {
"mainFile": "project-overview.md",
"autoReference": true,
"autoUpdate": true
}
},
"cursor": {
"ai": {
"enableCompletion": true,
"enableChat": true,
"contextFiles": [
"project-overview.md"
],
"hooks": {
"onConversationStart": [
{
"action": "readFile",
"file": "project-overview.md"
}
],
"onCodeModification": [
{
"action": "updateDocumentation",
"file": "project-overview.md"
}
]
},
"customInstructions": "在每次对话开始时,请先阅读 project-overview.md 文件以了解项目结构和功能。在完成代码修改后,请更新 project-overview.md 文件,添加新的功能或修改的内容。保持文档的准确性和最新状态。"
}
}
} 以及project-overview
# 番茄时间管理应用 - 项目概述
## 技术栈
- 前端框架:React + TypeScript
- UI组件库:Ant Design
- 路由管理:React Router
- 构建工具:Vite
- 数据存储:localStorage
## 项目结构
```
src/
├── assets/ # 静态资源
├── components/ # UI组件
│ ├── Timer.tsx # 计时器组件
│ ├── Statistics.tsx
│ ├── TimerRecords.tsx
│ ├── CategoryManager.tsx
│ ├── Settings.tsx
│ └── ...
├── hooks/ # 自定义钩子
│ ├── useTimer.ts # 计时器逻辑
│ ├── useCategories.ts
│ ├── useSettings.ts
│ ├── useStatistics.ts
│ ├── useTimerRecords.ts
│ └── useTagHistory.ts
├── pages/ # 页面组件
│ └── Home.tsx
├── services/ # 服务
│ └── TimerService.ts # 计时器服务(单例模式)
├── store/ # 状态管理
│ └── AppContext.tsx
├── types/ # 类型定义
│ └── index.ts
├── utils/ # 工具函数
├── App.tsx # 应用入口
└── main.tsx # 渲染入口
```
## 核心功能与实现
### 1. 计时器功能 (Timer.tsx, useTimer.ts, TimerService.ts)
- **状态管理**:使用 `useTimer` 钩子管理计时器状态,包括工作/休息/暂停/空闲
- **倒计时逻辑**:使用 `setInterval` 实现倒计时,支持暂停和恢复
- **通知功能**:计时结束时发送系统通知
- **画中画模式**:支持在浏览器中使用画中画模式显示计时器
- **标签功能**:可以为每次计时添加自定义标签
- **跨页面计时**:使用单例模式的 TimerService 确保在页面切换时计时器继续运行
- **事件系统**:使用发布-订阅模式实现计时器事件通知
- **状态持久化**:定期将计时器状态保存到 localStorage,确保页面刷新后能恢复状态
- **暂停状态UI**:在计时器暂停时同时显示继续和重置按钮,提升用户体验
- **智能记录保存**:重置计时器时,如果已计时超过3分钟,将调用complate保存记录;否则不保存
### 2. 数据管理 (AppContext.tsx)
- **全局状态**:使用 Context API 管理应用状态
- **数据持久化**:所有数据存储在 localStorage 中
- **状态类型**:
- `TimerRecord`: 记录每次计时的详细信息
- `CategoryType`: 分类信息
- `TimerSettings`: 计时器设置
- `Statistics`: 统计数据
### 3. 分类管理 (CategoryManager.tsx, useCategories.ts)
- 支持创建、编辑和删除分类
- 每个分类有名称和颜色标识
- 默认提供一个"默认"分类
### 4. 记录管理 (TimerRecords.tsx, useTimerRecords.ts)
- 记录每次计时的开始时间、结束时间、持续时间、类型和分类
- 支持按日期和分类筛选记录
- 支持删除记录
### 5. 统计功能 (Statistics.tsx, useStatistics.ts)
- 统计总工作时间和休息时间
- 按日期统计工作和休息时间
- 按分类统计工作时间
- 提供可视化图表展示统计数据
### 6. 设置功能 (Settings.tsx, useSettings.ts)
- 自定义工作和休息时长
- 设置是否自动开始下一个工作/休息周期
- 重置设置到默认值
## 数据结构
### TimerRecord (计时记录)
```typescript
{
id: string;
startTime: string;
endTime: string;
duration: number; // 持续时间(分钟)
type: 'work' | 'break'; // 工作或休息
categoryId: string | null; // 分类ID
completed: boolean; // 是否完成
label?: string; // 自定义标签/备注
}
```
### CategoryType (分类)
```typescript
{
id: string;
name: string;
color: string;
}
```
### TimerSettings (设置)
```typescript
{
workDuration: number; // 工作时长(分钟)
breakDuration: number; // 休息时长(分钟)
autoStartBreak: boolean; // 自动开始休息
autoStartWork: boolean; // 自动开始工作
}
```
### TimerState (计时器状态)
```typescript
{
state: 'idle' | 'working' | 'breaking' | 'paused';
timeLeft: number;
isActive: boolean;
currentSession: TimerRecord | null;
selectedCategoryId: string;
label: string;
}
```
## 最近修复和改进
- 计时器完成处理逻辑:在计时器完成时正确清除当前会话状态,避免状态不一致问题
- 跨页面计时功能:实现了 TimerService 单例服务,确保在页面切换时计时器继续运行
- 事件系统:使用发布-订阅模式实现计时器事件通知,提高组件间通信效率
- 暂停状态UI优化:在计时器暂停时同时显示继续和重置按钮,提升用户体验
- 智能记录保存:重置计时器时,根据已计时时长决定是否记录
- 超过3分钟:标记为未完成,保存到记录
- 不足3分钟:不保存记录学会了赶紧去试一下,好用的话,记得回来写感悟哈!
相关推荐
- 电脑中病毒的原因(电脑中病毒正常吗)
-
电脑中毒的原因有以下几方面:1.网页被挂病毒。2.电脑裸奔,无防病毒软件。3.执行一些不安全的程序。4.U盘等不安全介质。5.电脑漏洞不及时补,被后台种毒。为了电脑不中病毒要注意以下几方面:1.更新系...
- 手机psd转换成jpg最简单方式
-
可以使用photoshop工具,方法如下:1、首先打开PS软件,然后选择自己需要的JPG格式的图片,在PS中打开。2、接下来先按快捷键“Ctrl+j”将图片复制出来,防止后面操作对原图片有损...
- win7提示激活码过期怎么办(win7激活已过期)
-
以win7为例,出现这样的问题原因分析:电脑的win7系统激活过又重新提示要激活的原因是因为微软对网络上的秘钥进行封杀所以导致我们激活无效。具体的解决方法:1、我们打开dos命令窗口,在创立中输入“s...
- 联想笔记本光驱驱动下载(联想电脑光驱驱动器在哪)
-
开机时进入BIOS,具体按什么牌子不同,按键也不同,开机有提示的,选择启动项,把光驱启动的顺序放到第一.按F10保存,重新启动就是光驱启动啦不需要设置光驱驱动,笔记本自带光驱驱动光驱是电脑的硬件设备,...
- win10装机必备实用软件(win10电脑装机必备软件)
-
1、office大部分的版本如office2007、office2000、office2011、office2013、office2016、office365等都支持win10。2、需要注意...
- 迅雷无法下载的链接用什么下载
-
1.可以使用其他下载工具代替迅雷。2.迅雷可能无法下载的原因有很多,比如网络问题、软件故障等。其他下载工具可以提供类似的功能,但可能具有更好的稳定性和兼容性。3.一些常见的替代迅雷的下载工具包括...
- apple官方网站(apple官方网站旗舰店)
-
1、首先打开浏览器,输入https://www.apple.com/;2、即可浏览苹果官网。 苹果公司(AppleInc.)是美国一家高科技公司。由史蒂夫·乔布斯、斯蒂夫·沃兹尼亚克和罗·韦恩(R...
- 哪些手机用鸿蒙系统(都什么手机能用鸿蒙系统)
-
截至目前,国内有以下几款手机品牌可以装鸿蒙系统:1.华为:华为Mate40系列、P40系列、Mate30系列、MatePadPro系列等。2.荣耀:荣耀V40、荣耀30系列、荣耀X10系列等...
- 手机u盘读不出来了怎么修复(手机u盘读取不出来)
-
1、手机不支持OTG功能,所以将U盘连接到手机后,手机无法识别U盘的内容,因此显示不了;这种情况只能换台支持OTG功能的手机来连接U盘才行。2、手机支持OTG功能,但是使用的OTG线质量有问题导致无法...
- 笔记本散热器买哪种好(笔记本散热器买哪种好贴吧)
-
散热器有十大品牌:九州风神、超频三,酷冷至尊Tt、AVC、思民、捷冷、安钛克Antec、安耐美Enermax、海盗船Corsair。能位列十大品牌,每一种的质量和功能都有保障。、目前网上销量最高的是九...
-
- 打印机驱动一直安装失败(打印机驱动一直安装失败怎么办)
-
打印机驱动程序安装失败需要对电脑进行其他设置,详细步骤如下:1,在电脑桌面上找到【计算机】并用鼠标右击。2,右击后在出现的选项中找到【管理】选项并点击打开。3,接下里会进入到计算机控制台界面,在这里要根据自己的电脑选择64位或者32位,选择...
-
2026-01-14 12:55 liuian
- ctrl加谁是截图(ctrl和什么键可以截图)
-
第一种:Ctrl+PrScrn使用这个组合键截屏,获得的是整个屏幕的图片第二种:Alt+PrScrn这个组合键截屏,获得的结果是当前窗口的图片第三种:打开qq,使用快捷键Ctrl+...
- 技嘉主板bios设置启动顺序(技嘉主板bios设置启动顺序怎么设置)
-
启动顺序设置方法如下:1、重启电脑连续按[DEL]键进入BIOS设置,按DEL进入BIOS设置。2、按键盘方向键右键切换到BOOT选项,将windows10功能设置为"其它操作系统"...
-
- 目前台式电脑主机怎么选(台式主机选择)
-
每个人对电脑的性需要不同,因此根据自己家的家庭需要,选择合适的电脑即可。以下简单说明:1,双核处理器+2G内存+集成显卡+机械硬盘。性能满足上网、看电影、聊天、办公、玩象棋之类的小游戏。价格在2000以内可以买到;2,四核处理器+4G内存+...
-
2026-01-14 12:05 liuian
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
