用了 Trae 后,感觉离京东外卖不远了

前言

入手 Trae 开发已经有一段时间了,因为之前开发过一个vscode 插件,有点好奇如果让 Trae 来实现同样的功能会怎样。结果令人震惊 ------ 不到10分钟就完成了开发!这让我突然间对未来迷茫起来了。甚至觉得"送外卖的日子"似乎也不远了(说起来也巧了,今天碰巧就注册了京东众包😂)

vcode 插件介绍

我们先来看一下插件的效果

这个插件是智能代码命名工具,很多开发者在给代码命名时常常感到困扰,尤其是在英文水平有限的情况下,频繁地依赖翻译软件来寻找合适的命名。这个插件通过 AI 自动生成符合命名规范的名称,不仅避免了翻译软件带来的生硬翻译,还能提供更加自然、友好的命名建议。让你的代码命名更高效、更符合语境,提升整体开发体验。

AI 实现

首先我们先对功能进行拆解

然后运行 Trae

可以看到 Trae 直接给我们生成 项目结构

和插件核心代码实现

ts 复制代码
import { ExtensionContext, commands, window } from 'vscode';

function isChinese(text: string): boolean {
  return /[\u4e00-\u9fa5]/.test(text);
}

function validateText(text: string): { isValid: boolean; message?: string } {
  if (!text) {
    return { isValid: false, message: '请选择要转换的文本' };
  }
  if (!isChinese(text)) {
    return { isValid: false, message: '请选择中文文本' };
  }
  if (text.length > 20) {
    return { isValid: false, message: '选中文本不能超过20个字' };
  }
  return { isValid: true };
}

async function generateCodeName(text: string): Promise<string> {
  // TODO: 这里将集成火山引擎的AI模型
  // 临时返回一个示例转换结果
  return text.split('').join('_');
}

export async function activate(context: ExtensionContext) {
  const disposable = commands.registerCommand('vcode.generateCodeName', async () => {
    const editor = window.activeTextEditor;
    if (!editor) {
      return;
    }

    const selection = editor.selection;
    const text = editor.document.getText(selection);

    const validation = validateText(text);
    if (!validation.isValid) {
      window.showErrorMessage(validation.message!);
      return;
    }

    try {
      const codeName = await generateCodeName(text);
      await editor.edit(editBuilder => {
        editBuilder.replace(selection, codeName);
      });
    } catch (error) {
      window.showErrorMessage('生成代码命名失败:' + error.message);
    }
  });

  context.subscriptions.push(disposable);
}

这段代码与我之前手动开发的版本惊人地相似,只需要补充 AI 模型调用的部分就可以完整运行了

插件地址

源码

更多实践案例

除了这个简单的例子,我还想分享一个更现实的案例。也就在一周前,需求评审的时候产品问我能不能写个工具给运营处理一下 docs 里面的图片,把docs 里面的图片替换成 公司图床的链接,然后把 docs 给到知识库解析。我让产品先给我一个测试文档,我先试试,然后我就用 Trae 去实现了一下这个功能。结果需求还没开完,我就已经实现了,感觉就又离谱又神奇。

相关推荐
QQ1__8115175152 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态2 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子2 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室2 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI2 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing2 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者2 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册2 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李2 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢2 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web