我用了一周时间,复刻了一个Bolt new

打造下一代AI编程助手:Bubble Bolt项目深度解析

前段时间,看到Bolt new、lovable等AI编程项目大火,花了点时间研究了一下,用了换了国内的编码AI接口,快速复刻了一下,顺便学了一下关于web container相关的东西,选择了sandpack这个第三方库来实现编辑器和代码预览功能,下面是一些技术栈介绍和核心功能部分

项目技术栈解析

Bubble Bolt采用了当前最流行的全栈开发技术栈:

  • Next.js 13+:选择App Router架构,提供更好的性能和开发体验
  • TailwindCSS:实现响应式设计和现代化UI
  • Zustand:轻量级状态管理方案
  • SandPack:强大的代码预览引擎
  • Convex:实时数据库支持
  • shadcn/ui:高质量UI组件库

核心功能实现

1. AI对话系统

项目实现了一个智能的AI对话系统,支持自然语言交互。通过自定义hooks管理对话状态:

typescript 复制代码
// hooks/useStreamResult.ts
export const useStreamResult = () => {
  // 实现流式响应处理
  const handleStream = async (response) => {
    const reader = response.body.getReader();
    const decoder = new TextDecoder();
    
    while (true) {
      const {done, value} = await reader.read();
      if (done) break;
      const chunk = decoder.decode(value);
      // 处理流式数据
    }
  };
  return { handleStream };
};

2. 实时代码预览

使用SandPack实现代码实时预览功能,支持多种框架和语言:

typescript 复制代码
// components/custom/SandPackPreviewClient.tsx
import { SandpackProvider, SandpackPreview } from "@codesandbox/sandpack-react";

const SandPackPreviewClient = ({ code }) => {
  return (
    <SandpackProvider template="react">
      <SandpackPreview showNavigator={true} />
    </SandpackProvider>
  );
};

3. 工作区管理

项目使用Convex数据库存储和管理工作区信息:

typescript 复制代码
// convex/workspace.ts
export const createWorkspace = mutation(async ({ db }, { name, userId }) => {
  return await db.insert("workspaces", {
    name,
    userId,
    createdAt: new Date().toISOString(),
  });
});

项目部署和使用

要运行Bubble Bolt项目,按照以下步骤操作:

  1. 克隆项目并安装依赖:
bash 复制代码
git clone <repository-url>
cd bubble-bolt
pnpm install
  1. 配置环境变量:
bash 复制代码
cp .env.example .env.local
# 编辑.env.local文件,添加必要的环境变量
  1. 启动开发服务器:
bash 复制代码
pnpm dev

访问 http://localhost:3000 即可看到项目运行效果。

技术亮点

  1. 现代化架构:采用Next.js 13+ App Router,提供更好的性能和开发体验。

  2. 实时预览:集成SandPack,实现代码实时预览功能,支持多种框架。

  3. 状态管理:使用Zustand进行状态管理,相比Redux更轻量级,使用更简单。

  4. 实时数据同步:通过Convex数据库实现实时数据同步,提供流畅的多人协作体验。

  5. 优雅的UI设计:结合TailwindCSS和shadcn/ui,打造现代化的用户界面。

总结

Bubble Bolt项目展示了如何使用现代Web技术栈构建一个功能完整的AI编程助手。通过合理的技术选型和架构设计,实现了流畅的用户体验和强大的功能特性。无论是对于学习Next.js应用开发,还是了解AI编程助手的实现原理,这个项目都是一个很好的参考。

git: gitee.com/lin92n/bubb...

相关推荐
workflower2 小时前
用硬件换时间”与“用算法降成本”之间的博弈
人工智能·算法·安全·集成测试·无人机·ai编程
2301_764441334 小时前
OpenClaw框架的多Agent协作系统
人工智能·机器学习·语言模型·自然语言处理·ai编程
财经资讯数据_灵砚智能8 小时前
全球财经资讯日报(日间)2026年4月2日
大数据·人工智能·python·语言模型·ai编程
程序员鱼皮8 小时前
鱼皮 AI 导航网站,突然起飞了!
人工智能·ai·程序员·编程·ai编程
问道飞鱼10 小时前
【技术方案】面向 Web 系统的《全栈灰度部署方案设计》
前端·全栈·灰度发布
程序员小崔日记11 小时前
JetBrains 发布全新 AI IDE:AIR,会不会改变开发方式?
idea·ai编程·air·claude模型
zero159713 小时前
Python 8天极速入门笔记(大模型工程师专用):第七篇-文件操作 + 异常处理,大模型实战落地关键
python·ai编程·大模型编程语言
踩着两条虫13 小时前
AI驱动的Vue3应用开发平台深入探究(二十五):API与参考之Renderer API 参考
前端·javascript·vue.js·人工智能·低代码·前端框架·ai编程
KC27014 小时前
OpenAkita 深度解析:开源多Agent协作框架的实战指南
人工智能·aigc·ai编程
付威202314 小时前
让AI 花 5 小时造了一个完整马里奥游戏 — 零架构漂移如何做到
ai编程