Obsidian 插件开发,AI 协作者的实战手册:从需求描述到一键发布,让 TRAE 帮你搞定代码

news2026/3/15 14:43:55
1. 从“想法”到“描述”如何与你的AI协作者TRAE高效沟通你是不是也遇到过这种情况用Obsidian做笔记时总觉得少了点什么。比如你希望笔记里的某个关键词能自动关联到某个外部网站或者想在侧边栏一键生成当天的待办清单又或者想把一段文字快速转换成思维导图。你翻遍了社区插件市场发现要么功能太复杂要么就是没有完全符合你心意的。这时候一个念头冒出来要是能自己做一个插件就好了。但紧接着现实就给你泼了一盆冷水我不会写代码啊别急着放弃。今天我要分享的就是一条全新的、几乎零门槛的插件开发路径。它的核心不是让你去学TypeScript或者JavaScript而是让你学会如何与一位强大的AI协作者——比如TRAE——进行高效对话。你不需要懂编程语法你只需要清晰地描述你的“想法”。这个“想法”就是你的插件需求。那么如何把一个模糊的“想法”变成AI能理解的“功能描述”呢我总结了一个“三步描述法”亲测有效。第一步定义核心目标。用一句话说清楚你的插件要解决什么问题。这句话要像给朋友介绍一样简单。比如“我想做一个插件让我在阅读笔记时选中一个城市名就能在旁边显示当地的实时天气。” 或者 “我需要一个插件每天打开Obsidian时自动在日记里插入我昨天未完成的待办事项。” 目标越具体、越场景化AI的理解就越准确。第二步拆解关键动作。插件本质上是完成一系列自动化操作。你需要把这些操作步骤拆解出来。还是以天气插件为例关键动作可能包括1. 监听用户选中文本的事件。2. 判断选中的文本是否是有效的地名。3. 调用一个公开的天气API获取数据。4. 在选中文本附近以某种形式比如一个小弹窗展示获取到的天气信息。把这些步骤像清单一样列出来即使你不懂技术术语AI也能明白流程。第三步明确输入输出与交互。这是让插件变得好用的关键。输入用户需要做什么来触发插件比如选中文字后点击一个按钮或者直接右键菜单输出插件最终以什么形式呈现结果是弹出一个模态框在状态栏显示还是在笔记中插入一段文字交互用户能否进行一些设置比如设置API密钥、选择温度单位是摄氏度还是华氏度把这些细节描述清楚AI生成的代码才会更贴近你的使用习惯。我刚开始用TRAE时给它的指令是“帮我写一个Obsidian插件”。结果它返回的代码非常通用几乎就是官方模板。后来我学会了这样描述“请创建一个Obsidian插件功能是当我在编辑器中选中一段文本后按下快捷键CtrlShiftW插件能读取我选中的文本然后打开一个新的面板在这个面板里显示一个搜索框自动把选中的文本填入搜索框并模拟按下回车键进行网络搜索。” 你看虽然描述长了点但TRAE这次生成的代码骨架就非常对口我几乎没怎么修改就实现了核心功能。2. 环境搭建为你的AI协作者铺平道路好了现在你已经有了一个清晰的需求描述摩拳擦掌准备让TRAE大干一场了。别急在把需求“喂”给AI之前我们需要先准备好它的“工作台”——也就是本地开发环境。这一步听起来有点技术性但别怕你不需要理解每一步的原理只需要像按照食谱做菜一样一步步执行即可。整个过程大概需要10-15分钟而且大部分时间是在等待安装完成。首先你需要三个基础软件Obsidian、Node.js和Git。Obsidian你肯定已经有了。Node.js是运行JavaScript的环境也是我们编译插件所必需的。你去Node.js官网下载那个标着“LTS”长期支持版的安装包一路点击“下一步”安装就行。安装完成后打开电脑的命令行工具Windows上是PowerShell或CMDMac上是终端输入node -v和npm -v。如果能看到版本号比如“v18.19.0”和“10.2.3”那就说明安装成功了。npm是随着Node.js一起安装的包管理工具你可以把它想象成一个“软件仓库管理员”负责帮我们获取插件开发需要的各种零件。接下来是Git它是一个版本控制工具。简单说它就像一台“时光机”能记录你代码的每一次改动方便你回退或者协作。对于我们的AI协作开发来说Git更是至关重要。因为AI生成的代码可能需要多次迭代调整有了Git你就能放心大胆地尝试不行就退回到上一个能用的版本。我强烈推荐新手使用GitHub Desktop这个图形化工具它把复杂的Git命令变成了点点按钮非常直观。下载安装后用它登录你的GitHub账号没有的话需要注册一个这是免费的。环境准备好了我们就要创建插件项目了。这里有个小技巧不要自己从零开始写直接用Obsidian官方的插件模板。这就像做模型官方给了你一套高质量的骨架和说明书你只需要往上添加肌肉和皮肤你的功能就行了。获取模板有两种方式一是直接去GitHub上搜索“obsidian-sample-plugin”点击绿色的“Code”按钮选择“Download ZIP”把压缩包下载下来。二是如果你已经装了Git在命令行里输入git clone https://github.com/obsidianmd/obsidian-sample-plugin.git也可以。下载的模板压缩包你需要把它解压到正确的位置。找到你的Obsidian库就是存放你所有笔记的那个文件夹进入里面的.obsidian/plugins/目录注意.obsidian是隐藏文件夹你可能需要在系统设置里打开“显示隐藏文件”。把解压出来的文件夹名字类似obsidian-sample-plugin-master整个放进去。然后把这个文件夹的名字改成你想要的插件英文ID比如my-weather-helper。记住这个路径和名字后面会频繁用到。最后一步安装依赖。用命令行工具或者VS Code的终端进入你刚刚改名后的插件文件夹然后输入命令npm install或者yarn install并回车。这个命令会让npm或yarn去读取模板里的清单文件package.json把需要的“零件”都下载到本地的node_modules文件夹里。这个过程可能会花几分钟取决于你的网络速度。完成后你的AI协作者TRAE的“工作台”就正式搭建完毕了。3. 核心开发指挥TRAE编写与调试代码环境就绪现在进入最激动人心的环节让TRAE帮你写代码。打开你的代码编辑器我推荐使用Visual Studio Code因为它对TypeScript和前端开发的支持非常好而且自带终端。用VS Code打开你插件所在的文件夹。首先我们需要告诉TRAE我们的“工作台”是什么样子的。你可以把整个项目文件夹的压缩包上传给TRAE或者更简单把几个核心文件的内容复制给它看。主要是这三个文件manifest.json插件的身份证、package.json零件清单和main.ts目前是空的模板。你可以对TRAE说“我正在基于Obsidian官方插件模板开发一个插件这是manifest.json的内容请根据这个结构帮我实现以下功能……” 然后把上一章你精心准备好的“三步描述法”需求粘贴上去。TRAE在理解了上下文和需求后就会开始生成main.ts的代码。它生成的代码通常会包含一个完整的插件类结构包括onload插件加载时运行、onunload插件卸载时运行等方法以及你需要的命令注册、事件监听等逻辑。第一次拿到生成的代码不要急着运行先快速浏览一遍。重点关注那些有“TODO”注释或者看起来是核心逻辑的部分看看是否符合你的预期。接下来把TRAE生成的代码完整地复制到你的main.ts文件中覆盖原来的内容。保存文件后在终端里运行编译命令npm run dev。这个命令会启动一个监视进程自动将你写的TypeScript代码转换成Obsidian能执行的JavaScript代码输出为main.js。如果代码语法有错误终端会显示红色的错误信息。这是最常见的第一道坎。遇到错误怎么办这正是AI协作的精髓所在。不要自己埋头苦想。直接把终端里整段的错误信息复制下来连同你的main.ts相关代码片段一起扔回给TRAE。你可以这样说“我在编译时遇到了这个错误[粘贴错误信息]。这是我的相关代码[粘贴代码]。请帮我分析并修正。” TRAE不仅能修正语法错误还能解释错误原因这是一个绝佳的学习机会。我就是在一次次“报错-反馈-修正”的过程中慢慢理解了Obsidian API的一些基本用法和TypeScript的类型约束。代码编译通过后回到Obsidian。进入“设置” - “社区插件”找到你的插件名字来自manifest.json里的name字段打开开关。如果一切顺利你的插件就应该被加载了。根据你设计的功能去测试它比如尝试触发某个命令。如果插件没有按预期工作或者点击按钮没反应别慌打开开发者工具CtrlShiftI / CmdOptionI查看“控制台”标签页。任何由console.log输出的信息以及运行时的错误都会在这里显示。把这些错误信息和日志同样反馈给TRAE让它进行下一轮修正。这个“编码-编译-测试-调试”的循环可能会重复很多次。但请记住你的角色是“产品经理”和“测试员”而TRAE是“程序员”。你的任务是清晰地描述问题现象“点击按钮后弹窗没有出现控制台报了这样一个错误”而不是猜测技术原因。通过这种紧密的协作一个功能完整的插件原型就会逐渐成型。4. 迭代与优化像打磨产品一样完善插件第一个能跑起来的版本诞生了这值得庆祝但你可能发现它用起来还有点“糙”。比如界面全是英文设置项不够直观或者某些边缘情况会出错。别担心这才是插件开发的开始我们可以指挥TRAE对它进行精细打磨。首先是界面与交互的优化。Obsidian插件支持创建复杂的设置页面。如果你想让用户能配置API密钥、开关某些功能就需要用到PluginSettingTab。你可以对TRAE说“请为我的插件添加一个设置页面包含以下选项1. 一个文本框用于填写天气API的密钥。2. 一个下拉框让用户选择温度单位摄氏度或华氏度。3. 一个开关控制是否在启动时显示问候语。” TRAE会生成创建设置页的代码你只需要把描述性的文字如“温度单位”替换成中文即可。关于插件中文名有个小坑需要注意manifest.json里的name可以设为中文这样在插件列表里显示的就是中文名。但id字段强烈建议用英文否则在快捷键设置界面可能无法通过搜索找到你的插件命令。其次是错误处理与健壮性。一个成熟的插件必须考虑各种意外情况。比如网络请求失败怎么办用户输入了无效数据怎么办你可以要求TRAE“请为调用天气API的代码段添加错误处理。如果网络请求失败在控制台打印警告信息并在Obsidian界面上给用户一个友好的通知比如使用new Notice(获取天气失败请检查网络)。如果返回的数据格式不正确也进行类似的提示。” 增加这些“防御性”的代码能极大提升插件的稳定性和用户体验。然后是功能的渐进式增强。不要试图第一个版本就做一个“巨无霸”。采用“核心功能优先迭代增加”的策略。用Git的分支功能可以完美管理这个过程。当你完成第一个可用的核心版本后使用GitHub Desktop或命令git switch -c feat/xxx创建一个新的功能分支比如feat/add-settings-page。在这个分支上让TRAE帮你开发设置页面。开发测试完成后合并回主开发分支。接着再创建feat/support-more-cities分支增加多城市支持……每次只聚焦一个小的改进点这样管理和测试都更轻松也能持续获得正反馈。在这个过程中Obsidian的开发者工具是你的“显微镜”。除了用console.log你还可以使用更高级的调试手段。比如在“源代码”标签页找到你的插件编译后的main.js文件在关键行设置断点。当插件执行到那里时程序会暂停你可以查看当时所有变量的值一步步跟踪执行流程。这对于理解复杂逻辑或查找隐蔽Bug非常有用。把断点暂停时的变量状态截图给TRAE看它能更精准地定位问题所在。5. 发布与分享一键将你的作品推向社区经过一番打磨你的插件已经稳定好用了。是不是很想分享给其他Obsidian用户或者只是单纯想备份一个正式版本是时候学习如何发布了。整个过程其实很简单主要就是利用GitHub的Release功能。首先确保你本地的代码都已经通过git commit提交到了仓库并且推送git push到了你在GitHub上创建好的远程仓库里。在GitHub Desktop里这通常就是点一下“Push origin”按钮。你的代码现在有了一个安全的云端备份。发布的核心是“打标签”。你可以把标签Tag理解为一个重要的历史快照比如“v1.0.0正式版”。在GitHub仓库页面上点击“Releases”然后点击“Create a new release”。在“Choose a tag”下拉框里输入你的版本号比如“v0.1.0”并创建它。版本号建议遵循“主版本号.次版本号.修订号”的规则。初版可以从v0.1.0开始。接下来填写发布标题和描述。描述非常重要这是你向潜在用户介绍插件的地方。你应该用清晰的语言说明这个插件是做什么的解决了什么问题有什么特色功能如何安装和使用可以附上截图或动图。好的描述能大大增加插件的吸引力。最关键的一步来了生成发布文件。Obsidian社区插件市场识别的是包含main.js、manifest.json和styles.css这三个核心文件的ZIP压缩包。你不需要手动打包。在你插件项目的根目录下运行命令npm run build。这个命令会执行一次正式的构建生成优化后的main.js。然后手动选中main.js、manifest.json、styles.css这三个文件可能还有README.md等文档将它们打包成一个ZIP文件。在GitHub创建Release的页面上把这个ZIP文件拖到附件区域上传。最后点击“Publish release”。恭喜你的插件已经有了一个正式的发布页面。其他用户可以通过下载这个ZIP文件手动放入他们的.obsidian/plugins/文件夹来安装。如果你想更进一步提交到Obsidian官方社区插件列表让用户能直接在Obsidian内搜索并一键安装则需要去Obsidian的开发者网站提交审核。这需要你的插件拥有一个清晰的README.md说明文档并且代码开源在GitHub上。虽然多了一步但能让你的作品被更多人发现和使用。回过头看从最初的一个模糊想法到清晰的需求描述再到指挥TRAE一步步实现、调试、优化最后打包发布。你全程没有手写一行复杂的业务逻辑代码但却完成了一个真正可用的、解决自己实际问题的工具。这种“AI协作者”的模式真正打破了工具创造的壁垒。它让你从“使用者”变成了“创造者”这种成就感是单纯使用现成插件无法比拟的。我最开始用这个方法做了个简单的文本处理插件后来胆子大了甚至做了一个管理本地图片素材库的中型插件。每次打开Obsidian用上自己做的功能那种感觉真的很棒。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2410984.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…