百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

一个高效使用cursor开发项目的方法,怎么让 AI 写的代码不跑题?

zhezhongyun 2025-07-21 19:06 6 浏览

最近又用 cursor 做了一个小应用,番茄时钟,用来管理自己的时间,提高效率。然后使用 cursor 开发的过程中。有了一些新的感悟。找到了一条可以让 Curosr不跑题的办法。


生成一份详细的项目资料。然后配置.cursorrule。让Cursor每次开发都参考资料,并自动更新。当然这些也都可以让 AI 帮你完成。下面的用 3 个步骤完成配置。


(ps:这是一个小项目,大型的项目可能效果暂不明确。但是对一个纯用 Cursor开发的小应用,效果嘎嘎香,再也不跑题了)




  1. 给项目写一份详细的资料

指令:

写一个详细的项目资料project-overview.md ,等我下次再提需求时,你可以参考快速熟悉项目。



  1. 给项目配置一个 cursorrule

指令:

给项目配置一个 cursorrule



  1. 让 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分钟:不保存记录


学会了赶紧去试一下,好用的话,记得回来写感悟哈!

相关推荐

HashMap详解(hashmap lru)

讲解步骤基础知识工作原理关键代码核心方法基础知识数组结构数组接口,在查询数据方面,具备优势链表结构链表结构,在增删数据方面,具备优势红黑树结构红黑树结构,在查询数据方面,数据量较大的时候,具备一定的优...

升级内核,UC浏览器电脑版v2.0.570.0下载

IT之家(www.ithome.com):升级内核,UC浏览器电脑版v2.0.570.0下载7月21日晚,UC浏览器电脑版发布了v2.0正式版,最新的版本号是2.0.570.0。此次更新的最大亮点是内...

MySQL惊天陷阱:left join时选on还是where?

前天写SQL时本想通过AleftBjoinonand后面的条件来使查出的两条记录变成一条,奈何发现还是有两条。后来发现joinonand不会过滤结果记录条数,只会根据and后的条...

一个高效使用cursor开发项目的方法,怎么让 AI 写的代码不跑题?

最近又用cursor做了一个小应用,番茄时钟,用来管理自己的时间,提高效率。然后使用cursor开发的过程中。有了一些新的感悟。找到了一条可以让Curosr不跑题的办法。生成一份详细的项目资...

某通信公司笔试题,你会做几道?(通信行业行测题)

笔试部分1.描述下面代码中两个static各自的含义:staticvoidfunc(void){staticunsignedinti;}参考答案:行1,static表示静态...

新手学Python避坑,学习效率狂飙! 二、Python 代码缩进

在Python里,缩进有着极其重要的作用,它被用于界定代码块。与其他多数编程语言使用大括号{}来划分代码块不同,Python依靠缩进来明确代码的层次结构。下面分享缩进问题,并且给出避坑的方法...

Python缩进规范详解与最佳实践(python缩进讲解)

Python的缩进规则是强制性的语法要求,绝对不能乱缩进!作为一门用缩进表示代码块的语言,Python的缩进错误会导致程序直接崩溃。以下是关于缩进规范的全面解析:一、Python缩进的底层逻辑代...

深度解析ConcurrentHashMap1.8源码分析

想必大家对HashMap数据结构并不陌生,JDK1.7采用的是数组+链表的方式,JDK1.8采用的是数组+链表+红黑树的方式。虽然JDK1.8对于HashMap有了很大的改进,提高了存取效率,但是线程...

星河战神暴风旋转刃好不好 暴风旋转刃属性详解

星河战神暴风旋转刃好不好?暴风旋转刃怎么得?小编为大家分享星河战神暴风旋转刃属性图鉴,希望可以帮助到大家。暴风旋转刃85级满级属性战力加成暴风旋转刃分类:僚机初始:1星属性:风满星:5星暴风旋...

假面骑士亚极陀全形态盘点(假面骑士亚极陀形态合集)

《假面骑士亚极陀》的形态设计延续了空我的属性差异化思路,但更强调“觉醒”与“进化”的主题。从基础形态的属性专精到闪耀形态的等离子爆发,每个形态都承载着角色成长与剧情转折。数据对比不仅揭示了力量...

膛线磨没了子弹精度到底是怎么受影响的呢?

这是一个回复:那么咱们就来深究这个问题吧——当膛线磨没了,子弹的精度到底是怎么受影响的呢?到底是不是就成了“滑膛枪”射程、精度是不是差了一点?先说结论——膛线磨没了,只能让这把枪成为“信仰之枪”,根本...

【莫莫老师亲授】公考行测图形推理3大属性规律!提分利器

在公务员考试的行测科目中,图形推理是高频考点之一,而属性规律作为基础题型中的核心模块,常通过图形的对称性、曲直性、开闭性三大属性考查考生的观察与归纳能力。本文将从定义、特点、常见考法及例题分析入手,系...

DNF驱魔属性合并,技能重做解读(dnf驱魔加强了吗)

作者:B蜀黍前言本轮职业平衡驱魔进行了力驱法驱合二为一,部分技能重做和技能优化。形态方面:新增四神系技能且可柔化,力系技能加快出手速度,一觉从1秒瞬发单段脱手改为3秒站桩多段,形态逆向优化,实战体验...

拉满一个3级配件?还是升6个2级配件,橙装升级最优解方案揭秘!

各位车长,试验型配件已经重新发放!即日起至3月31日,在这期间登录游戏就能免费领到6个试验型配件和700个合金原件(已领取的玩家不再重复获得)。今天就和各位车长简单聊一聊:活动期间一共能获得多少合金元...

CAD动态块制作方法—旋转动态块(cad动态块制作教程 视频教程)

CAD动态块制作方法—可见性动态块CAD动态块制作方法—拉伸动态块今天来讲一下含有旋转动作的动态块制作方法。我们用立面索引符号来举例。旋转动态块首先制作一个带有属性定义的立面索引符号的图块。(此步...