
转载声明:本文系转载自微信公众号「手工川」的《吴恩达 Claude Code 笔记》第 9 期。原文版权归作者与公众号所有;正文整理自 DeepLearning.AI 与 Anthropic 官方课程材料。若需商业使用请联络原作者。 原文链接:在微信中打开 · 专辑目录
“Design to Code”——这个口号在软件开发领域回响了十余年,无数工具尝试搭建从设计师的创意到工程师代码之间的桥梁,但往往收效甚微。现在,AI Agent 的出现,似乎第一次让我们看到了实现这一梦想的曙GIT。本期,我们将见证 Claude Code 作为这座桥梁的构建者,完成从设计到产品的惊人一跃。
欢迎来到《吴恩达 Claude Code 笔记》的第九期,也是我们课程解读系列的最后一期。我是手工川。
经历了前面八期的学习和实践,我们已经从基础的代码理解、功能开发,一路走到了测试驱动调试、并行开发、乃至云端 GitHub 流程自动化。我们手中的 Claude Code,其形象也从一个“代码补全工具”,逐渐成长为一个能够深度参与软件工程全生命周期的“智能体伙伴”。
今天,我们将迎来本系列课程的终极实战项目,一个足以被称为“毕业设计”的挑战:完全从零开始,仅依据一份 Figma 设计稿,构建一个功能完备、接入真实数据的 Next.js 全栈应用。
这不仅仅是一次对 Claude Code 综合能力的全面检验,更是一次对未来 AI 原生开发工作流的深刻预演。
“Design to Code”的承诺,我听了不下十年。从早期的 Photoshop 插件,到后来的 Sketch、Zeplin、Avocode,再到 Figma 自己的代码生成功能,每一代工具都在努力缩短设计与开发之间的距离。但它们大多停留在“样式翻译”的层面——将设计元素的 CSS 属性提取出来,生成的代码往往缺乏结构性、可维护性差,离真正的生产代码相去甚远。
本期课程所展示的工作流,我认为代表了一种根本性的范式转变。AI Agent 的介入,让“Design to Code”从“翻译”升级为了“理解与创造”。
这背后的关键,正是 MCP (Model Context Protocol)。如果说 Claude Code 是一个聪明的大脑,那么 MCP 就是为这个大脑接上了“感官”和“四肢”的神经接口。通过 Figma MCP,它获得了“视觉”,能够理解设计稿的布局、组件和设计语言;通过 Playwright MCP,它获得了与浏览器“交互”的能力,可以像人一样打开页面、截图、验证 UI。
当一个 AI 同时拥有了“视觉”、“交互能力”和强大的“代码生成逻辑”,它就不再是一个被动的翻译器了。它成为了一个能够看懂需求、动手实现、并自行检验的初级前端工程师。而我们,则成为了它的“产品经理”和“技术总监”。这,就是未来。
我们的终极项目,目标是复刻一个展示美国联邦储备经济数据(FRED)的仪表盘。起点,只有一份 Figma 设计稿。

我们首先在本地创建一个空的 Next.js 项目,这将是我们应用的基础骨架。
npx create-next-app@latest .
接下来是至关重要的一步:为 Claude Code 接上“眼睛”和“手”。
连接 Figma (眼睛):课程中介绍了两种连接方式。
Enable Dev Mode MCP Server。这需要在付费的 Pro 计划及以上才能使用。我们在终端中使用 claude mcp add 命令,将 Figma MCP Server 添加到 Claude Code 的工具集中。
连接 Playwright (手/验证工具):我们同样使用 claude mcp add 命令,添加 Playwright MCP Server。

配置完成后,我们可以在 Claude Code 中使用 /mcp 命令,检查两个服务器是否都已成功连接。

环境就绪,大戏开场。我们向 Claude Code 发出了第一个核心指令。

这个 Prompt 的指令链条非常清晰:
figma dev MCP server 来分析它。recharts 库来创建图表。playwright MCP server 来检查最终成果与设计稿的相似度。为了应对这个复杂的任务,课程中建议将模型切换到能力更强的 Opus。
Claude Code 接收指令后,它的 Agentic 工作流启动了:
Get_image 和 Get_Code 工具,“看懂”了设计稿的视觉样式和基础代码。app/ 目录下,开始创建符合 React 规范的、组件化的页面代码。localhost:3000,截取一张当前页面的快照,用于和原始设计稿进行对比。片刻之后,我们看到了初步的成果。令人印象深刻的是,AI 生成的页面不仅在布局和样式上高度还原了设计稿,甚至在一些细节上(如柱状图的渐变效果)比原始设计稿还要精致一些。

一个漂亮的“空壳”已经完成,接下来是注入灵魂——真实数据。我们向 Claude Code 发出了第二个指令:
populate these charts with real-world data from FRED
这个看似简单的指令,触发了一系列复杂的、真正体现 AI Agent 智能的行为:
WebSearch 工具,去搜索“FRED API”,找到了官方文档。services/fredApi.js 文件,封装了所有与 FRED API 交互的数据请求逻辑。useEffect 和 useState 等 React Hooks,在组件加载时调用 API 服务,获取真实数据,并更新图表状态。
这个过程完美地模拟了一个人类工程师的工作流程:接到需求 -> 查阅资料 -> 发现前置条件 -> 请求资源 -> 编写代码 -> 集成调试。

最终,我们刷新浏览器,仪表盘上显示的不再是静态的占位符,而是来自美国联邦储备数据库的、实时更新的经济指标。在短短几分钟内,我们从一份静态的设计图,得到了一个美观、交互式且由真实数据驱动的全栈 Web 应用。
随着这个终极项目的完成,我们对吴恩达与 Anthropic 这门课程的解读也走到了尾声。
回顾这九期的旅程,我们不仅仅是学会了如何使用一个新工具,更是亲身经历了一次开发思想的变革。我们从最基础的文件操作开始,逐步掌握了测试驱动、并行开发、GitHub 协作、Notebook 重构,直到今天,我们亲手“导演”了一出从设计创意到软件产品的全流程 AI 大戏。
课程的总结言简意赅,却道出了与 Agentic AI 协作的精髓:提供清晰的指令,明确的上下文,并指向相关的文件。这背后,是我们开发者角色的转变——从代码的“生产者”,变为 AI 工作流的“编排者”。
AI 编程的时代已经到来,但这并不意味着程序员的黄昏。恰恰相反,它将我们从繁琐、重复的底层实现中解放出来,让我们能更专注于软件的架构、用户的体验和创意的实现。世上无难事,只要有 Claude。
感谢 Elie Schoppik 老师的精彩讲解,也感谢各位读者的一路相伴。虽然课程解读到此结束,但 AI 辅助开发的探索之旅,才刚刚开始。在接下来的文章中,我将脱离课程本身,分享一些我个人在使用 Claude Code 过程中的最佳实践,以及对这一系列搬运工作流的复盘总结,敬请期待。

课程项目源码 (Final Project Source Code):
课程官方文件与 Prompt (Official Course Files & Prompts):
DeepLearning.AI 课程主页 (DeepLearning.AI Course Homepage):
# 在你的项目目录中执行
npx create-next-app@latest .# 添加 Figma 官方 Dev Mode MCP Server
claude mcp add --transport http figma-dev-mode-mcp-server http://127.0.0.1:3845/mcp
# 添加 Playwright MCP Server
claude mcp add playwright npx @playwright/mcp@latest第一阶段:视觉复刻
Cmd + L (Mac) 或 Ctrl + L (Windows) 复制图层链接,替换到 Prompt 中。Using the following figma mockup (在此处粘贴你的 Figma 链接) use the figma dev MCP server to analyze the mockup and build the underlying code in this next.js application. Use the recharts library for creating charts to make this a web application. Check how this application looks using the playwright MCP server and verify it looks as close to the mock as possible.第二阶段:数据注入
populate these charts with real-world data from FRED如果你的 Figma 账户不是付费的 Professional Plan 或更高版本,无法使用官方的 Dev Mode MCP Server,可以使用由社区提供的 Framelink Figma MCP Server 作为免费替代方案。
YOUR-KEY 替换为你自己的 Figma API Key。claude mcp add "Framelink Figma MCP" -- npx -y figma-developer-mcp --figma-api-key=YOUR-KEY --stdio