{"id":5426,"date":"2025-09-13T20:41:07","date_gmt":"2025-09-13T20:41:07","guid":{"rendered":"https:\/\/pokecon.jp\/job\/?p=5426"},"modified":"2025-09-13T20:41:07","modified_gmt":"2025-09-13T20:41:07","slug":"%e3%81%82%e3%82%8b%e3%81%b9%e3%81%8d%e5%a0%b4%e6%89%80%e3%81%ab%e5%b8%b0%e3%82%8d%e3%81%86%ef%bc%81react%e3%81%ab%e7%ab%8b%e3%81%a1%e8%bf%94%e3%82%8aclaude-code-playwright-mcp-figma-mcp%e3%81%a7","status":"publish","type":"post","link":"https:\/\/pokecon.jp\/job\/5426\/","title":{"rendered":"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620"},"content":{"rendered":"\n<\/p>\n<div>\n<p data-line=\"0\" class=\"code-line\">VTeacher\u6240\u5c5e\u306eSatoko\u3067\u3059\uff01<br \/>\u666e\u6bb5\u306f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3092\u30e1\u30a4\u30f3\u3068\u3057\u3066\u3001QA\u7684\u306a\u3053\u3068\u3084\u9032\u6357\u7ba1\u7406\u306a\u3069\u3001\u3044\u308d\u3044\u308d\u3084\u3063\u3066\u3044\u307e\u3059\u3002<br \/>\u6700\u8fd1\u306e\u8da3\u5473\u306fAI\u3068\u306e\u304a\u3057\u3083\u3079\u308a\u3067\u3059\uff01<\/p>\n<p data-line=\"6\" class=\"code-line\">\u3068\u3053\u308d\u3067\uff01<\/p>\n<p data-line=\"8\" class=\"code-line\">\u305b\u3063\u304b\u304fFigma\u306bMCP\u30b5\u30fc\u30d0\u30fc\u304c\u3042\u308b\u306e\u306b\u3001\u751f\u6210\u3055\u308c\u305f\u30b3\u30fc\u30c9\u304c\u3044\u307e\u3044\u3061\u3067\u3001\u4e00\u6642\u7684\u306b\u8a71\u984c\u306b\u306a\u3063\u305f\u4ee5\u964d\u306f\u3001Figma MCP\u30b5\u30fc\u30d0\u30fc\u306e\u5229\u7528\u3092\u8ae6\u3081\u3066\u3057\u307e\u3063\u305f\u4eba\u306f\u3044\u307e\u305b\u3093\u304b\uff1f<\/p>\n<p data-line=\"10\" class=\"code-line\">\u3044\u307e\u3001\u5fc3\u306e\u4e2d\u3067\uff08\u3042\u3001\u306f\u3044\u30fb\u30fb\u30fb\uff09\u3068\u7b54\u3048\u305f\u4eba\u305d\u3053\u306e\u3042\u306a\u305f\uff01<\/p>\n<p data-line=\"12\" class=\"code-line\">\u3053\u306e\u8a18\u4e8b\u306e\u7d9a\u304d\u3092\u662f\u975e\u8aad\u3093\u3067\u304f\u3060\u3055\u3044\uff01<\/p>\n<h2 id=\"%E3%82%A8%E3%83%BC%E3%82%B8%E3%82%A7%E3%83%B3%E3%83%88%E6%A9%9F%E8%83%BD%EF%BC%9D%E4%BA%BA%E3%81%AB%E4%BE%9D%E5%AD%98%E3%81%97%E3%81%A6%E3%81%84%E3%81%9F%E8%81%B7%E4%BA%BA%E6%B0%97%E8%B3%AA%E3%81%AE%E4%BD%9C%E6%A5%AD%E3%82%92%E7%B9%B0%E3%82%8A%E8%BF%94%E3%81%99\" data-line=\"14\" class=\"code-line\">\n \u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u6a5f\u80fd\uff1d\u4eba\u306b\u4f9d\u5b58\u3057\u3066\u3044\u305f\u8077\u4eba\u6c17\u8cea\u306e\u4f5c\u696d\u3092\u7e70\u308a\u8fd4\u3059<\/h2>\n<p data-line=\"16\" class=\"code-line\">\u3044\u307e\u3067\u306f\u300c\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u300d\u3068\u3044\u3046\u6a5f\u80fd\u304c\u4e00\u822c\u7684\u306b\u306a\u3063\u3066\u304d\u307e\u3057\u305f\u304c\u3001\u79c1\u304c\u521d\u3081\u3066\u3053\u306e\u8a00\u8449\u3092\u805e\u3044\u305f\u306e\u306fRAG\uff08LangChain\uff09\u3092\u89e6\u3063\u305f\u3068\u304d\u3067\u3057\u305f\u3002\u3053\u306e\u9803\u306eAgent\u306f\u65e7\u6a5f\u80fd\u3068\u306a\u308a\u3001\u73fe\u5728\u306f\u975e\u63a8\u5968\u306e\u3088\u3046\u3067\u3059\u304c\u3001\u305d\u308c\u3092\u898b\u305f\u3068\u304d\u306f\u3084\u306f\u308a\u885d\u6483\u7684\u3067\u3001AI\u306e\u918d\u9190\u5473\u3092\u611f\u3058\u305f\u3053\u3068\u3092\u899a\u3048\u3066\u3044\u307e\u3059\u3002\u300c\u30ec\u30d3\u30e5\u30fc\u3092AI\u306b\u4efb\u305b\u305f\u3044\uff01\u300d\u306a\u3069\u3001\u540c\u3058\u767a\u60f3\u3084\u671f\u5f85\u3092\u6301\u3064\u4eba\u304c\u5897\u3048\u305f\u3053\u3068\u304c\u3001\u3044\u307e\u306eAI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u306e\u767a\u5c55\u306b\u3064\u306a\u304c\u3063\u305f\u306e\u3060\u3068\u601d\u3063\u3066\u3044\u307e\u3059\uff01<\/p>\n<p data-line=\"18\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__61426db29cbca\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__61426db29cbca\" data-content=\"https%3A%2F%2Fgihyo.jp%2Fbook%2F2023%2F978-4-297-13839-4\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/gihyo.jp\/book\/2023\/978-4-297-13839-4\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/gihyo.jp\/book\/2023\/978-4-297-13839-4<\/a><\/p>\n<ul data-line=\"19\" class=\"code-line\">\n<li data-line=\"19\" class=\"code-line\">\u7b2c5\u7ae0\u3000LangChain\u306e\u6d3b\u7528\n<ul data-line=\"20\" class=\"code-line\">\n<li data-line=\"20\" class=\"code-line\">5.2\u3000Agents\n<ul data-line=\"21\" class=\"code-line\">\n<li data-line=\"21\" class=\"code-line\">Agents\u306e\u6982\u8981<\/li>\n<li data-line=\"22\" class=\"code-line\">Agents\u306e\u4f7f\u7528\u4f8b<\/li>\n<li data-line=\"23\" class=\"code-line\">Agents\u306e\u4ed5\u7d44\u307f\u2015 <strong>ReAct (Reasoning and Acting)<\/strong> \u3068\u3044\u3046\u8003\u3048\u65b9<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h2 id=\"%E6%9C%AC%E9%A1%8C%E3%81%A7%E3%81%99%E3%81%8C%E3%80%81figma-mcp%E3%82%B5%E3%83%BC%E3%83%90%E3%83%BC%E3%82%92%E8%AB%A6%E3%82%81%E3%81%9F%E4%BA%BA%E3%81%8C%E5%A2%97%E3%81%88%E3%81%A6%E3%81%8D%E3%81%9F%EF%BC%9F\" data-line=\"25\" class=\"code-line\">\n \u672c\u984c\u3067\u3059\u304c\u3001Figma MCP\u30b5\u30fc\u30d0\u30fc\u3092\u8ae6\u3081\u305f\u4eba\u304c\u5897\u3048\u3066\u304d\u305f\uff1f<\/h2>\n<p data-line=\"27\" class=\"code-line\">\u672c\u984c\u306b\u623b\u308a\u307e\u3059\uff01<\/p>\n<p data-line=\"29\" class=\"code-line\">\u305b\u3063\u304b\u304fFigma\u306eMCP\u30b5\u30fc\u30d0\u30fc\u304c\u3042\u308b\u306e\u306b\u3001\u671f\u5f85\u3059\u308b\u30b3\u30fc\u30c9\u304c\u751f\u6210\u3055\u308c\u306a\u3044\u3001\u4eca\u306f\u4f7f\u3063\u3066\u3044\u306a\u3044\u3001Figma MCP\u30b5\u30fc\u30d0\u30fc\u306e\u5229\u7528\u3092\u8ae6\u3081\u305f\u3001\u3068\u3044\u3046\u4eba\u304c\u6563\u898b\u3055\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<p data-line=\"31\" class=\"code-line\"><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/83e9e91a6d0c-20250912.png\" width=\"250\" class=\"md-img\" loading=\"lazy\"\/><br \/><em>\u3057\u304f\u3057\u304f\u3070\u306a\u306a<\/em><\/p>\n<p data-line=\"34\" class=\"code-line\">\u305f\u3057\u304b\u306b\u30fb\u30fb\u30fb<br \/>Figma MCP\u30b5\u30fc\u30d0\u30fc\u306e\u5229\u7528\u3092Vibe Coding\u983c\u308a\u3067\u3084\u3063\u3066\u3057\u307e\u3046\u3068\u3001\u305d\u306e\u81ea\u52d5\u3067\u751f\u6210\u3055\u308c\u305f\u30b3\u30fc\u30c9\u306e\u30c7\u30b6\u30a4\u30f3\u518d\u73fe\u7387\u306f\u3044\u307e\u3072\u3068\u3064\u3060\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p data-line=\"37\" class=\"code-line\">\u305d\u3053\u3067\uff01\uff01\uff01<\/p>\n<p data-line=\"39\" class=\"code-line\">\u539f\u70b9\u3067\u3042\u308b <strong>ReAct (Reasoning and Acting)<\/strong> \u306b\u7acb\u3061\u8fd4\u308a\u307e\u3057\u3087\u3046\uff01<\/p>\n<div class=\"code-block-container\">\n<pre><code class=\"code-line\" data-line=\"41\">ReAct \u306f\u300cReasoning\uff08\u601d\u8003\uff09\u300d\u3068\u300cActing\uff08\u884c\u52d5\uff09\u300d\u3092\u4ea4\u4e92\u306b\u51fa\u529b\u3055\u305b\u308b\u30d7\u30ed\u30f3\u30d7\u30c8\u624b\u6cd5\uff0f\u30d1\u30e9\u30c0\u30a4\u30e0\u3067\u3001\u601d\u8003\u3068\u884c\u52d5\u306e\u4ea4\u4e92\u53cd\u5fa9\u304c ReAct (Reasoning and Acting) \u306e\u6838\u3067\u3059\u3002\n\n1. \u30e2\u30c7\u30eb\u304c\u300cReasoning Traces:\uff08\u601d\u8003\uff09\u300d\u3092\u51fa\u529b\u3057\u3066\u65b9\u91dd\u3092\u6c7a\u3081\u308b\u3002\n2. \u65b9\u91dd\u306b\u5f93\u3063\u3066\u300cActions:\uff08\u884c\u52d5\uff09\u300d\u3092\u8d77\u3053\u3059\u3002\n3. \u300cObservations:\uff08\u89b3\u5bdf\uff09\u300d\u3068\u3057\u3066\u30e2\u30c7\u30eb\u306f\u305d\u308c\u3092\u8e0f\u307e\u3048\u3066\u518d\u3073 Reasoning Traces \u306b\u623b\u308b\u3002\n\nhttps:\/\/research.google\/blog\/react-synergizing-reasoning-and-acting-in-language-models\/\n<\/code><\/pre>\n<\/div>\n<p data-line=\"51\" class=\"code-line\"><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/f70541b96297-20250912.png\" class=\"md-img\" loading=\"lazy\"\/><\/p>\n<p data-line=\"53\" class=\"code-line\">\u565b\u307f\u7815\u3044\u3066\u3001\u4eca\u56de\u306e\u4f8b\u306b\u5f53\u3066\u306f\u3081\u308b\u3068\u30fb\u30fb\u30fb<\/p>\n<p data-line=\"55\" class=\"code-line\"><strong>\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u6a5f\u80fd\uff1d\u4eba\u306b\u4f9d\u5b58\u3057\u3066\u3044\u305f\u8077\u4eba\u6c17\u8cea\u306e\u4f5c\u696d\u3092\u81ea\u52d5\u5316\u3057\u3066\u7e70\u308a\u8fd4\u3059\u6a5f\u80fd<\/strong><\/p>\n<h2 id=\"react%E6%80%9D%E8%80%83%E3%81%A7%E4%BB%95%E6%A7%98%E3%83%89%E3%83%AA%E3%83%96%E3%83%B3\" data-line=\"57\" class=\"code-line\">\n ReAct\u601d\u8003\u3067\u4ed5\u69d8\u30c9\u30ea\u30d6\u30f3<\/h2>\n<p data-line=\"59\" class=\"code-line\">\u5b9f\u8df5\u7684\u306b\u306f Spec Kit \u3084 Kiro \u306a\u3069\u3001\u4ed5\u69d8\u30c9\u30ea\u30d6\u30f3\uff08Spec-driven\uff09\u306e\u6d41\u308c\u306b\u306a\u3063\u3066\u304d\u3066\u3044\u308b\u3068\u601d\u3044\u307e\u3059\u3002Viable coding\uff08\u5b9f\u7528\u7684\u306a\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\uff09\u3068\u3057\u3066\u3001\u6539\u3081\u3066Figma\u306eMCP\u30b5\u30fc\u30d0\u30fc\u306b\u6311\u6226\u3057\u3066\u307f\u307e\u3057\u3087\u3046\uff01Claude Code\u306a\u3069\u306f\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u306a\u306e\u3067ReAct\u306e\u601d\u8003\u3092\u3082\u3068\u3082\u3068\u6c72\u3093\u3067\u3044\u307e\u3059\u304c\u3001\u305d\u306eReAct\u3092\u3055\u3089\u306bReAct\u3067\u5305\u3093\u3067\u3042\u3052\u308b\u30a4\u30e1\u30fc\u30b8\u3067\u3084\u3063\u3066\u307f\u307e\u3059\uff01<\/p>\n<h3 id=\"%E4%BA%BA%E9%96%93%E3%81%8C%E3%82%84%E3%82%8B%E5%A0%B4%E5%90%88%E3%81%AE%E6%89%8B%E9%A0%86%E6%9B%B8%E3%82%92spec%EF%BC%88%E4%BB%95%E6%A7%98%EF%BC%89%E3%81%A8%E3%81%99%E3%82%8B\" data-line=\"61\" class=\"code-line\">\n \u4eba\u9593\u304c\u3084\u308b\u5834\u5408\u306e\u624b\u9806\u66f8\u3092Spec\uff08\u4ed5\u69d8\uff09\u3068\u3059\u308b<\/h3>\n<p data-line=\"63\" class=\"code-line\">\u4eba\u529b\u3067\u3001Figma\u304b\u3089CSS\u3092\u53cd\u6620\u3055\u305b\u308b\u5834\u5408\u3001\u6b21\u306e\u4f5c\u696d\u3092\u7e70\u308a\u8fd4\u3059\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p data-line=\"65\" class=\"code-line\"><strong>1. Figma\u3092\u898b\u3066\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u30af\u30ea\u30c3\u30af\u3057\u3066\u3001CSS\u3092\u78ba\u8a8d<\/strong> \u2192 <strong>\u601d\u8003<\/strong><br \/><strong>2. CSS\u3092\u30d5\u30a1\u30a4\u30eb\u306b\u53cd\u6620\uff08\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\uff09<\/strong> \u2192 <strong>\u884c\u52d5<\/strong><br \/><strong>3. \u76ee\u3067\u898b\u3066\u5dee\u7570\u304c\u306a\u3044\u304b\u3092\u78ba\u8a8d<\/strong> \u2192 <strong>\u89b3\u5bdf<\/strong><\/p>\n<p data-line=\"69\" class=\"code-line\">\u3053\u308c\u3092\u4ed5\u69d8\u30c9\u30ea\u30d6\u30f3\u3067Viable coding\u7684\u306b\u3084\u308b\u306b\u306f\u3069\u3046\u3057\u305f\u3089\u826f\u3044\u304b\u3092\u8003\u3048\u3066\u3044\u304d\u307e\u3059\uff01<\/p>\n<blockquote data-line=\"72\" class=\"code-line\">\n<ol data-line=\"72\" class=\"code-line\">\n<li data-line=\"72\" class=\"code-line\">Figma\u3092\u898b\u3066\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u30af\u30ea\u30c3\u30af\u3057\u3066\u3001CSS\u3092\u78ba\u8a8d<\/li>\n<\/ol>\n<\/blockquote>\n<p data-line=\"74\" class=\"code-line\">\u3053\u3053\u306f Figma MCP\u30b5\u30fc\u30d0\u30fc \u3092\u4f7f\u3048\u3070\u826f\u3055\u305d\u3046\u3067\u3059\u3002<br \/>MCP\u30b5\u30fc\u30d0\u30fc\u7d4c\u7531\u3067\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3057\u307e\u3059\u3002<\/p>\n<blockquote data-line=\"78\" class=\"code-line\">\n<ol start=\"2\" data-line=\"78\" class=\"code-line\">\n<li data-line=\"78\" class=\"code-line\">CSS\u3092\u30d5\u30a1\u30a4\u30eb\u306b\u53cd\u6620\uff08\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\uff09<\/li>\n<\/ol>\n<\/blockquote>\n<p data-line=\"80\" class=\"code-line\">\u3053\u3053\u306f\u751f\u6210AI\uff08Claude Code\u3084Codex\u306a\u3069\uff09\u306b\u4efb\u305b\u308c\u3070\u826f\u3055\u305d\u3046\u3067\u3059\u3002<\/p>\n<blockquote data-line=\"83\" class=\"code-line\">\n<ol start=\"3\" data-line=\"83\" class=\"code-line\">\n<li data-line=\"83\" class=\"code-line\">\u76ee\u3067\u898b\u3066\u5dee\u7570\u304c\u306a\u3044\u304b\u3092\u78ba\u8a8d<\/li>\n<\/ol>\n<\/blockquote>\n<p data-line=\"85\" class=\"code-line\">\u3053\u3053\u3092\u3069\u3046\u3059\u308b\u304b\u3001\u3067\u3059\u304c\u3001\u3053\u308c\u306fPlaywright\u306eMCP\u30b5\u30fc\u30d0\u30fc\u3092\u4f7f\u3046\u3053\u3068\u306b\u3057\u307e\u3059\u3002\u3054\u5b58\u77e5\u306e\u901a\u308a\u3001Playwright\u306fE2E\u30c6\u30b9\u30c8\u306e\u5b9a\u756a\u3067\u3001VRT\uff08Visual Regression Test\uff09\u306b\u3082\u5bfe\u5fdc\u3057\u3066\u3044\u307e\u3059\u306e\u3067\u3001\u3064\u307e\u308a\u3001E2E\u30c6\u30b9\u30c8\u306b\u3088\u308a\u3001\u76ee\u8996\u78ba\u8a8d\u306e\u5f79\u5272\uff08Observations\uff09\u3092\u62c5\u5f53\u3055\u305b\u307e\u3059\uff01<\/p>\n<p data-line=\"87\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__ba9fd6dcec252\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__ba9fd6dcec252\" data-content=\"https%3A%2F%2Fplaywright.dev%2Fdocs%2Ftest-snapshots\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/playwright.dev\/docs\/test-snapshots\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/playwright.dev\/docs\/test-snapshots<\/a><\/p>\n<p data-line=\"89\" class=\"code-line\">Figma\u3092\u958b\u3044\u3066\u3001\u3042\u3089\u304b\u3058\u3081\u4eba\u529b\u3067\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8\u3092\u64ae\u3063\u3066\u4fdd\u5b58\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046\uff01\u3053\u308c\u3092\u4f7f\u3063\u3066E2E\u30c6\u30b9\u30c8\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304a\u304d\u307e\u3059\u3002<br \/>AI\u306b\u306f\u3001VRT\uff08Visual Regression Test\uff09\u306e\u8981\u9818\u3067 <strong>\u89b3\u5bdf<\/strong> \u3092\u884c\u3063\u3066\u30c6\u30b9\u30c8\u306b\u5408\u683c\u3059\u308b\u307e\u3067\u7e70\u308a\u8fd4\u3059\u3088\u3046\u306b\u6307\u793a\u3057\u307e\u3059\u3002<\/p>\n<h4 id=\"%E6%95%B4%E7%90%86%E3%81%99%E3%82%8B%E3%81%A8%E6%AC%A1%E3%81%AE%E3%82%88%E3%81%86%E3%81%AA%E6%89%8B%E9%A0%86%E3%81%A7%E3%81%99%E3%80%82\" data-line=\"92\" class=\"code-line\">\n \u6574\u7406\u3059\u308b\u3068\u6b21\u306e\u3088\u3046\u306a\u624b\u9806\u3067\u3059\u3002<\/h4>\n<ul data-line=\"94\" class=\"code-line\">\n<li data-line=\"94\" class=\"code-line\">\u554f\u984c\u306e\u5207\u308a\u5206\u3051\u3092\u3057\u3084\u3059\u304f\u3059\u308b\u305f\u3081\u306b\u3001\u53e4\u5178\u7684\u3067\u306f\u3042\u308a\u307e\u3059\u304c\u3001\u3044\u304d\u306a\u308a\u52d5\u7684\u30d5\u30a1\u30a4\u30eb\uff08.tsx \u306a\u3069\uff09\u306b\u624b\u3092\u52a0\u3048\u308b\u306e\u3067\u306f\u306a\u304f <strong>\u3044\u3063\u305f\u3093\u9759\u7684\u30d5\u30a1\u30a4\u30eb\uff08.html\uff09\u3092\u4f5c\u3063\u3066\u304b\u3089<\/strong> \u52d5\u7684\u30d5\u30a1\u30a4\u30eb\u306b\u53cd\u6620\u3059\u308b\u3053\u3068\u3092\u63a8\u5968\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n<div class=\"code-block-container\">\n<pre class=\"language-shell\"><code class=\"language-shell code-line\" data-line=\"96\"><span class=\"token number\">1<\/span>. \u601d\u8003: Figma MCP\u30b5\u30fc\u30d0\u30fc \u7d4c\u7531\u3067\u30c7\u30fc\u30bf\u53d6\u5f97\n<span class=\"token number\">2<\/span>. \u884c\u52d5: Claude Code\u306a\u3069\u3067\u3001html\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\n<span class=\"token number\">3<\/span>. \u78ba\u8a8d: Playwright MCP\u30b5\u30fc\u30d0\u30fc\u7d4c\u7531\u3067VRT\u306e\u30c6\u30b9\u30c8\u30b3\u30fc\u30c9\u3092\u5b9f\u65bd\n- \u30c6\u30b9\u30c8\u306b\u5408\u683c\uff08\u5dee\u757010%\u4ee5\u5185\uff09\u3059\u308b\u307e\u3067\u7e70\u308a\u8fd4\u3059\n<\/code><\/pre>\n<\/div>\n<p data-line=\"103\" class=\"code-line\"><strong>\u7d50\u8ad6\u304b\u3089\u8a00\u3046\u3068\u3001\u3068\u3066\u3082\u826f\u3044\u3067\u3059\uff01<\/strong><\/p>\n<p data-line=\"105\" class=\"code-line\">\u3053\u306e\u65b9\u6cd5\u306a\u3089\u3001\u3042\u308b\u7a0b\u5ea6\u9ad8\u3081\u306e\u7cbe\u5ea6\u304c\u51fa\u305b\u308b\u3068\u601d\u3044\u307e\u3059\uff01<br \/>\uff08\u30c7\u30b6\u30a4\u30ca\u30fc\u306b\u3088\u3063\u3066\u30ec\u30a4\u30e4\u30fc\u306e\u5206\u3051\u65b9\u7b49\u306b\u7656\u304c\u3042\u308b\u306e\u3067\u3001\u30d7\u30ed\u30f3\u30d7\u30c8\u8abf\u6574\u304c\u5fc5\u8981\u3067\u3059\uff09<\/p>\n<h2 id=\"%E3%82%84%E3%81%A3%E3%81%A6%E3%81%BF%E3%81%BE%E3%81%97%E3%82%87%E3%81%86%EF%BC%81\" data-line=\"109\" class=\"code-line\">\n \u3084\u3063\u3066\u307f\u307e\u3057\u3087\u3046\uff01<\/h2>\n<h3 id=\"figma-mcp%E3%82%B5%E3%83%BC%E3%83%90%E3%83%BC\" data-line=\"111\" class=\"code-line\">\n Figma MCP\u30b5\u30fc\u30d0\u30fc<\/h3>\n<p data-line=\"113\" class=\"code-line\">\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u7248\u306eFigma\u304c\u5fc5\u8981\u3067\u3059\u3002<\/p>\n<p data-line=\"115\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__453a4b3dcf3b2\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__453a4b3dcf3b2\" data-content=\"https%3A%2F%2Fhelp.figma.com%2Fhc%2Fja%2Farticles%2F32132100833559-Dev-Mode-MCP%25E3%2582%25B5%25E3%2583%25BC%25E3%2583%2590%25E3%2583%25BC%25E5%2588%25A9%25E7%2594%25A8%25E3%2582%25AC%25E3%2582%25A4%25E3%2583%2589\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/help.figma.com\/hc\/ja\/articles\/32132100833559-Dev-Mode-MCP%E3%82%B5%E3%83%BC%E3%83%90%E3%83%BC%E5%88%A9%E7%94%A8%E3%82%AC%E3%82%A4%E3%83%89\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/help.figma.com\/hc\/ja\/articles\/32132100833559-Dev-Mode-MCP\u30b5\u30fc\u30d0\u30fc\u5229\u7528\u30ac\u30a4\u30c9<\/a><\/p>\n<p data-line=\"117\" class=\"code-line\">\u73fe\u5728\u306f\u30aa\u30fc\u30d7\u30f3\u30d9\u30fc\u30bf\u7248\u3067\u3001\u521d\u671f\u7248\u3088\u308a\u5909\u66f4\u304c\u52a0\u3048\u3089\u308c\u3066\u3044\u308b\u5370\u8c61\u3067\u3059\u3002<br \/>\u57fa\u672c\u7684\u306a\u90e8\u5206\u306f\u540c\u3058\u3067\u3059\u304c\u3001UI\u306f\u3061\u3087\u304f\u3061\u3087\u304f\u5909\u308f\u3063\u3066\u3044\u307e\u3059\uff01<\/p>\n<blockquote data-line=\"120\" class=\"code-line\">\n<p data-line=\"120\" class=\"code-line\">\u30d7\u30ed\u30d5\u30a7\u30c3\u30b7\u30e7\u30ca\u30eb\u3001\u30d3\u30b8\u30cd\u30b9\u3001\u307e\u305f\u306f\u30a8\u30f3\u30bf\u30fc\u30d7\u30e9\u30a4\u30ba\u30d7\u30e9\u30f3\u306eDev\u307e\u305f\u306f\u30d5\u30eb\u30b7\u30fc\u30c8\u3067\u5229\u7528\u3067\u304d\u307e\u3059<\/p>\n<\/blockquote>\n<p data-line=\"122\" class=\"code-line\">\u3053\u306e\u3088\u3046\u306b\u66f8\u304b\u308c\u3066\u3044\u307e\u3059\u304c\u3001\u7533\u8acb\u5f8c\u306f\u73fe\u6642\u70b9\u3067\u7d043\u65e5\u9593\u306e\u7121\u6599\u4f53\u9a13\u3092\u5229\u7528\u3067\u304d\u308b\u306f\u305a\u3067\u3059\uff01<\/p>\n<p data-line=\"124\" class=\"code-line\">Figma MCP\u30b5\u30fc\u30d0\u30fc\u306e\u8a2d\u5b9a\u306f\u3001Claude Code\u3067\u3057\u305f\u3089\u3001\u6b21\u306e\u901a\u308a\u3067\u3059\uff01<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-shell\"><code class=\"language-shell code-line\" data-line=\"126\">claude mcp <span class=\"token function\">add<\/span> <span class=\"token parameter variable\">--transport<\/span> sse figma-dev-mode-mcp-server http:\/\/<span class=\"token punctuation\">{<\/span>Figma\u304c\u8868\u793a\u3059\u308bMCP\u30b5\u30fc\u30d0\u30fc\u306eURL\u3092\u4f7f\u3063\u3066\u304f\u3060\u3055\u3044<span class=\"token punctuation\">}<\/span>\n<\/code><\/pre>\n<\/div>\n<h3 id=\"playwright-mcp%E3%82%B5%E3%83%BC%E3%83%90%E3%83%BC\" data-line=\"130\" class=\"code-line\">\n Playwright MCP\u30b5\u30fc\u30d0\u30fc<\/h3>\n<p data-line=\"132\" class=\"code-line\">Playwright\uff08\u672c\u4f53\uff09\u306f\u3053\u3061\u3089\u3067\u3059\u3002<\/p>\n<p data-line=\"134\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__8f332ce12d9d8\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__8f332ce12d9d8\" data-content=\"https%3A%2F%2Fwww.npmjs.com%2Fpackage%2Fplaywright\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/playwright\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/www.npmjs.com\/package\/playwright<\/a><\/p>\n<p data-line=\"136\" class=\"code-line\">MCP\u30b5\u30fc\u30d0\u30fc\u306f\u3053\u3061\u3089\u3067\u3059\u3002<\/p>\n<p data-line=\"138\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__a40f4adc0c904\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__a40f4adc0c904\" data-content=\"https%3A%2F%2Fgithub.com%2Fmicrosoft%2Fplaywright-mcp\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/github.com\/microsoft\/playwright-mcp\" style=\"display:none\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">https:\/\/github.com\/microsoft\/playwright-mcp<\/a><\/p>\n<p data-line=\"140\" class=\"code-line\">Playwright MCP\u30b5\u30fc\u30d0\u30fc\u306e\u8a2d\u5b9a\u306f\u3001Claude Code\u3067\u3057\u305f\u3089\u3001\u6b21\u306e\u901a\u308a\u3067\u3059\uff01<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-shell\"><code class=\"language-shell code-line\" data-line=\"142\">claude mcp <span class=\"token function\">add<\/span> playwright npx @playwright\/mcp@latest\n<\/code><\/pre>\n<\/div>\n<h3 id=\"vrt%E3%81%AE%E3%83%86%E3%82%B9%E3%83%88%E3%82%B3%E3%83%BC%E3%83%89\" data-line=\"146\" class=\"code-line\">\n VRT\u306e\u30c6\u30b9\u30c8\u30b3\u30fc\u30c9<\/h3>\n<p data-line=\"148\" class=\"code-line\">\u671f\u5f85\u5024\u3068\u306a\u308b\u6b63\u89e3\u753b\u50cf\u304c\u5fc5\u8981\u306a\u306e\u3067\u3001\u3042\u3089\u304b\u3058\u3081Figma\u3092\u958b\u3044\u3066\u4eba\u529b\u3067\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8\u3092\u64ae\u3063\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n<p data-line=\"150\" class=\"code-line\">\u30c6\u30b9\u30c8\u30b3\u30fc\u30c9\u306e\u30b5\u30f3\u30d7\u30eb\u306f\u6b21\u306e\u901a\u308a\u3067\u3059\uff01<br \/>\uff0810%\u306e\u5dee\u7570\u307e\u3067\u3067\u3042\u308c\u3070\u5408\u683c\u3068\u3057\u3066\u3044\u307e\u3059\uff09<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-ts\"><code class=\"language-ts code-line\" data-line=\"153\"><span class=\"token keyword\">import<\/span> <span class=\"token punctuation\">{<\/span> chromium <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'@playwright\/test'<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">import<\/span> <span class=\"token punctuation\">{<\/span> compareScreenshot <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">from<\/span> <span class=\"token string\">'.\/vrt-utils'<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">import<\/span> path <span class=\"token keyword\">from<\/span> <span class=\"token string\">'path'<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">import<\/span> fs <span class=\"token keyword\">from<\/span> <span class=\"token string\">'fs'<\/span><span class=\"token punctuation\">;<\/span>\n\n\n<span class=\"token keyword\">async<\/span> <span class=\"token keyword\">function<\/span> <span class=\"token function\">runTest<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'test.html\u3068vrt.png\u3092\u6bd4\u8f03\u30c6\u30b9\u30c8\u3092\u958b\u59cb\u3057\u307e\u3059...'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n  \n  <span class=\"token keyword\">const<\/span> browser <span class=\"token operator\">=<\/span> <span class=\"token keyword\">await<\/span> chromium<span class=\"token punctuation\">.<\/span><span class=\"token function\">launch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n  <span class=\"token keyword\">const<\/span> context <span class=\"token operator\">=<\/span> <span class=\"token keyword\">await<\/span> browser<span class=\"token punctuation\">.<\/span><span class=\"token function\">newContext<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n  <span class=\"token keyword\">const<\/span> page <span class=\"token operator\">=<\/span> <span class=\"token keyword\">await<\/span> context<span class=\"token punctuation\">.<\/span><span class=\"token function\">newPage<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n  <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span>\n    \n    <span class=\"token keyword\">const<\/span> testHtmlPath <span class=\"token operator\">=<\/span> path<span class=\"token punctuation\">.<\/span><span class=\"token function\">join<\/span><span class=\"token punctuation\">(<\/span>process<span class=\"token punctuation\">.<\/span><span class=\"token function\">cwd<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">'test.html'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">const<\/span> fileUrl <span class=\"token operator\">=<\/span> <span class=\"token template-string\"><span class=\"token template-punctuation string\">`<\/span><span class=\"token string\">file:\/\/<\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>testHtmlPath<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">`<\/span><\/span><span class=\"token punctuation\">;<\/span>\n\n    <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">`<\/span><span class=\"token string\">\u30da\u30fc\u30b8\u3092\u958b\u304d\u307e\u3059: <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>fileUrl<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">`<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    \n    <span class=\"token keyword\">await<\/span> page<span class=\"token punctuation\">.<\/span><span class=\"token function\">goto<\/span><span class=\"token punctuation\">(<\/span>fileUrl<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    \n    <span class=\"token keyword\">await<\/span> page<span class=\"token punctuation\">.<\/span><span class=\"token function\">waitForTimeout<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8\u3092\u6bd4\u8f03\u3057\u307e\u3059...'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    \n    <span class=\"token keyword\">const<\/span> screenshotBuffer <span class=\"token operator\">=<\/span> <span class=\"token keyword\">await<\/span> page<span class=\"token punctuation\">.<\/span><span class=\"token function\">screenshot<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    \n    <span class=\"token keyword\">const<\/span> tempScreenshotPath <span class=\"token operator\">=<\/span> path<span class=\"token punctuation\">.<\/span><span class=\"token function\">join<\/span><span class=\"token punctuation\">(<\/span>process<span class=\"token punctuation\">.<\/span><span class=\"token function\">cwd<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">'e2e\/vrt\/temp-screenshot.png'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    fs<span class=\"token punctuation\">.<\/span><span class=\"token function\">writeFileSync<\/span><span class=\"token punctuation\">(<\/span>tempScreenshotPath<span class=\"token punctuation\">,<\/span> screenshotBuffer<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">`<\/span><span class=\"token string\">\u4e00\u6642\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8\u3092\u4fdd\u5b58\u3057\u307e\u3057\u305f: <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>tempScreenshotPath<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">`<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    \n    <span class=\"token keyword\">const<\/span> result <span class=\"token operator\">=<\/span> <span class=\"token keyword\">await<\/span> <span class=\"token function\">compareScreenshot<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">{<\/span>\n      page<span class=\"token punctuation\">,<\/span>\n      name<span class=\"token operator\">:<\/span> <span class=\"token string\">'test-html'<\/span><span class=\"token punctuation\">,<\/span>\n      baseImagePath<span class=\"token operator\">:<\/span> path<span class=\"token punctuation\">.<\/span><span class=\"token function\">join<\/span><span class=\"token punctuation\">(<\/span>process<span class=\"token punctuation\">.<\/span><span class=\"token function\">cwd<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">'vrt.png'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>\n      threshold<span class=\"token operator\">:<\/span> <span class=\"token number\">0.1<\/span><span class=\"token punctuation\">,<\/span> \n    <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">`<\/span><span class=\"token string\">\u6bd4\u8f03\u7d50\u679c: \u5dee\u7570 <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span><span class=\"token punctuation\">(<\/span>result<span class=\"token punctuation\">.<\/span>diffPercentage <span class=\"token operator\">*<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">toFixed<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">)<\/span><span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token string\">% (\u8a31\u5bb9\u5024: 10%)<\/span><span class=\"token template-punctuation string\">`<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token template-string\"><span class=\"token template-punctuation string\">`<\/span><span class=\"token string\">\u7570\u306a\u308b\u30d4\u30af\u30bb\u30eb\u6570: <\/span><span class=\"token interpolation\"><span class=\"token interpolation-punctuation punctuation\">${<\/span>result<span class=\"token punctuation\">.<\/span>pixelDiff<span class=\"token interpolation-punctuation punctuation\">}<\/span><\/span><span class=\"token template-punctuation string\">`<\/span><\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n\n    <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>result<span class=\"token punctuation\">.<\/span>diffPercentage <span class=\"token operator\"> <span class=\"token number\">0.1<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span>\n      <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30c6\u30b9\u30c8\u6210\u529f: \u753b\u50cf\u306e\u5dee\u7570\u304c\u8a31\u5bb9\u7bc4\u56f2\u5185\u3067\u3059'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">else<\/span> <span class=\"token punctuation\">{<\/span>\n      <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">error<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30c6\u30b9\u30c8\u5931\u6557: \u753b\u50cf\u306e\u5dee\u7570\u304c\u8a31\u5bb9\u7bc4\u56f2\u3092\u8d85\u3048\u3066\u3044\u307e\u3059'<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n      process<span class=\"token punctuation\">.<\/span><span class=\"token function\">exit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n  <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span>error<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span>\n    <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">error<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30c6\u30b9\u30c8\u5b9f\u884c\u4e2d\u306b\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u307e\u3057\u305f:'<\/span><span class=\"token punctuation\">,<\/span> error<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    process<span class=\"token punctuation\">.<\/span><span class=\"token function\">exit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n  <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">finally<\/span> <span class=\"token punctuation\">{<\/span>\n    \n    <span class=\"token keyword\">await<\/span> browser<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n  <span class=\"token punctuation\">}<\/span>\n<span class=\"token punctuation\">}<\/span>\n\n\n<span class=\"token function\">runTest<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">catch<\/span><span class=\"token punctuation\">(<\/span>err <span class=\"token operator\">=&gt;<\/span> <span class=\"token punctuation\">{<\/span>\n  <span class=\"token builtin\">console<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">error<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">'\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u307e\u3057\u305f:'<\/span><span class=\"token punctuation\">,<\/span> err<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n  process<span class=\"token punctuation\">.<\/span><span class=\"token function\">exit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n<\/span><\/code><\/pre>\n<\/div>\n<p data-line=\"227\" class=\"code-line\">\u6e96\u5099\u304c\u3067\u304d\u307e\u3057\u305f\uff01<br \/>\u3042\u3068\u306fAI\u306b\u6307\u793a\u3059\u308b\u3060\u3051\u3067\u3059\u3002<\/p>\n<h2 id=\"ai%E3%81%B8%E3%81%AE%E6%8C%87%E7%A4%BA%EF%BC%88%E3%83%97%E3%83%AD%E3%83%B3%E3%83%97%E3%83%88%EF%BC%89\" data-line=\"230\" class=\"code-line\">\n AI\u3078\u306e\u6307\u793a\uff08\u30d7\u30ed\u30f3\u30d7\u30c8\uff09<\/h2>\n<p data-line=\"232\" class=\"code-line\">\u6b21\u306e\u3088\u3046\u306a\u30d7\u30ed\u30f3\u30d7\u30c8\u3092\u4f7f\u7528\u3057\u3066\u3001\u30c6\u30b9\u30c8\u304c\u5408\u683c\u3059\u308b\u307e\u3067AI\u306b\u4fee\u6b63\u3092\u7e70\u308a\u8fd4\u3057\u3066\u3082\u3089\u3044\u307e\u3057\u3087\u3046\uff01<\/p>\n<div class=\"code-block-container\">\n<pre class=\"language-shell\"><code class=\"language-shell code-line\" data-line=\"234\">\u6b21\u306e\u30bf\u30b9\u30af\u3092\u9806\u306b\u5b9f\u884c\u3057\u3066\u304f\u3060\u3055\u3044\u3002\n\n- <span class=\"token punctuation\">[<\/span> <span class=\"token punctuation\">]<\/span> <span class=\"token number\">1<\/span>. Reasoning Traces:\uff08\u601d\u8003\uff09: \u6b21\u306eURL\u304b\u3089Figma\u306e\u5bfe\u8c61\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3057\u3066\u3057\u3066\u304f\u3060\u3055\u3044\u3002\nhttps:\/\/<span class=\"token punctuation\">{<\/span>Figma\u4e0a\u306e\u5bfe\u8c61\u3092\u53f3\u30af\u30ea\u30c3\u30af\u3057\u3066\u300c\u9078\u629e\u7bc4\u56f2\u306e\u30ea\u30f3\u30af\u300d\u306eURL<span class=\"token punctuation\">}<\/span>\n- <span class=\"token punctuation\">[<\/span> <span class=\"token punctuation\">]<\/span> <span class=\"token number\">2<\/span>. Actions:\uff08\u884c\u52d5\uff09: \u30bf\u30b9\u30af1\u3067\u53d6\u5f97\u3057\u305f\u30c7\u30fc\u30bf\u3092\u5fe0\u5b9f\u306b\u53cd\u6620\u3057\u305ftest.html\u3092\u4f5c\u6210\u3057\u3066\u304f\u3060\u3055\u3044\u3002\n- <span class=\"token punctuation\">[<\/span> <span class=\"token punctuation\">]<\/span> <span class=\"token number\">3<\/span>. Observations:\uff08\u89b3\u5bdf\uff09: Playwrite\u3092\u4f7f\u7528\u3057\u3066 <span class=\"token variable\"><span class=\"token variable\">`<\/span>test:vrt:compare-test-html<span class=\"token variable\">`<\/span><\/span> \u3092\u5b9f\u884c\u3057\u3066\u304f\u3060\u3055\u3044\u3002\n\n\u30bf\u30b9\u30af3\u306e\u30c6\u30b9\u30c8\u306b\u5408\u683c\u3059\u308b\u307e\u3067\u3001\u30bf\u30b9\u30af1\u306b\u623b\u3063\u3066 test.html \u3092\u4fee\u6b63\u3059\u308b\u4f5c\u696d\u3092\u7e70\u308a\u8fd4\u3057\u3066\u304f\u3060\u3055\u3044\u3002\n<\/code><\/pre>\n<\/div>\n<h3 id=\"%E5%AE%9F%E9%9A%9B%E3%81%AB%E3%82%84%E3%81%A3%E3%81%A6%E3%81%BF%E3%81%9F%E7%B5%90%E6%9E%9C%E3%81%AF%E3%81%93%E3%81%A1%E3%82%89%E3%81%A7%E3%81%99%EF%BC%81\" data-line=\"245\" class=\"code-line\">\n \u5b9f\u969b\u306b\u3084\u3063\u3066\u307f\u305f\u7d50\u679c\u306f\u3053\u3061\u3089\u3067\u3059\uff01<\/h3>\n<p data-line=\"247\" class=\"code-line\">\u7d50\u679c\u3068\u3057\u3066\u306f\u5de6\u5bc4\u305b\uff08\u30bb\u30f3\u30bf\u30ea\u30f3\u30b0\u5fd8\u308c\uff1f10%\u306e\u8a31\u5bb9\u3092\u3057\u3066\u3044\u308b\uff09\u306b\u306f\u306a\u3063\u3066\u3057\u307e\u3063\u3066\u3044\u307e\u3059\u304c\u3001\u304b\u306a\u308a\u306e\u518d\u73fe\u7387\u306b\u306f\u306a\u3063\u3066\u3044\u308b\u304b\u3068\u601d\u3044\u307e\u3059\uff01<\/p>\n<div class=\"s_table\"><table data-line=\"249\" class=\"code-line\">\n<thead data-line=\"249\" class=\"code-line\">\n<tr data-line=\"249\" class=\"code-line\">\n<th>\u671f\u5f85\u5024<\/th>\n<th>\u7d50\u679c<\/th>\n<\/tr>\n<\/thead>\n<tbody data-line=\"251\" class=\"code-line\">\n<tr data-line=\"251\" class=\"code-line\">\n<td><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/136d8750f2ce-20250912.png\" class=\"md-img\" loading=\"lazy\"\/><\/td>\n<td><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/42707127a934-20250912.png\" class=\"md-img\" loading=\"lazy\"\/><\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p data-line=\"253\" class=\"code-line\">\u305c\u3072\u3068\u3082\u3001\u307f\u306a\u3055\u3093\u3082\u8a66\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\uff01<\/p>\n<h4 id=\"%E6%AC%A1%E3%81%AE%E3%81%8A%E3%81%99%E3%81%99%E3%82%81%E8%A8%98%E4%BA%8B%3A\" data-line=\"255\" class=\"code-line\">\n \u6b21\u306e\u304a\u3059\u3059\u3081\u8a18\u4e8b:<\/h4>\n<p data-line=\"257\" class=\"code-line\"><span class=\"embed-block zenn-embedded zenn-embedded-card\"><iframe id=\"zenn-embedded__729b3eb34e9a7\" src=\"https:\/\/embed.zenn.studio\/card#zenn-embedded__729b3eb34e9a7\" data-content=\"https%3A%2F%2Fzenn.dev%2Fvteacher%2Farticles%2Farticle-tanaka-20250909\" frameborder=\"0\" scrolling=\"no\" loading=\"lazy\"><\/iframe><\/span><a target=\"_blank\" href=\"https:\/\/zenn.dev\/vteacher\/articles\/article-tanaka-20250909\" style=\"display:none\" target=\"_blank\">https:\/\/zenn.dev\/vteacher\/articles\/article-tanaka-20250909<\/a><\/p>\n<\/div>\n\n<br \/><a href=\"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2\">\u5143\u306e\u8a18\u4e8b\u3092\u78ba\u8a8d\u3059\u308b <\/a><\/p>\n","protected":false},"excerpt":{"rendered":"VTeacher\u6240\u5c5e\u306eSatoko\u3067\u3059\uff01\u666e\u6bb5\u306f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3092\u30e1\u30a4\u30f3\u3068\u3057\u3066\u3001QA\u7684\u306a\u3053\u3068\u3084\u9032\u6357\u7ba1\u7406\u306a\u3069\u3001\u3044\u308d\u3044\u308d\u3084\u3063\u3066\u3044\u307e\u3059\u3002\u6700\u8fd1\u306e\u8da3\u5473\u306fAI\u3068\u306e\u304a\u3057\u3083\u3079\u308a\u3067\u3059\uff01 \u3068\u3053\u308d\u3067\uff01 \u305b\u3063\u304b\u304fFigma\u306bMCP\u30b5\u30fc\u30d0\u30fc\u304c\u3042\u308b\u306e\u306b [&hellip;]","protected":false},"author":1,"featured_media":5427,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[2],"tags":[],"class_list":["post-5426","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-hatena-blog"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.6 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620 - \u30dd\u30b1\u30b3\u30f3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2\" \/>\n<meta property=\"og:locale\" content=\"ja_JP\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620 - \u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"og:description\" content=\"VTeacher\u6240\u5c5e\u306eSatoko\u3067\u3059\uff01\u666e\u6bb5\u306f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3092\u30e1\u30a4\u30f3\u3068\u3057\u3066\u3001QA\u7684\u306a\u3053\u3068\u3084\u9032\u6357\u7ba1\u7406\u306a\u3069\u3001\u3044\u308d\u3044\u308d\u3084\u3063\u3066\u3044\u307e\u3059\u3002\u6700\u8fd1\u306e\u8da3\u5473\u306fAI\u3068\u306e\u304a\u3057\u3083\u3079\u308a\u3067\u3059\uff01 \u3068\u3053\u308d\u3067\uff01 \u305b\u3063\u304b\u304fFigma\u306bMCP\u30b5\u30fc\u30d0\u30fc\u304c\u3042\u308b\u306e\u306b [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2\" \/>\n<meta property=\"og:site_name\" content=\"\u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"article:published_time\" content=\"2025-09-13T20:41:07+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/09\/1757796067_og-base-w1200-v2.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\n\t<meta property=\"og:image:height\" content=\"630\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"info@pokecon.jp\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u57f7\u7b46\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"info@pokecon.jp\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u63a8\u5b9a\u8aad\u307f\u53d6\u308a\u6642\u9593\" \/>\n\t<meta name=\"twitter:data2\" content=\"2\u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/5426\\\/\"},\"author\":{\"name\":\"info@pokecon.jp\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"headline\":\"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620\",\"datePublished\":\"2025-09-13T20:41:07+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/5426\\\/\"},\"wordCount\":160,\"image\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/09\\\/1757796067_og-base-w1200-v2.png\",\"articleSection\":[\"\u306f\u3066\u306a\u30d6\u30ed\u30b0\"],\"inLanguage\":\"ja\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/5426\\\/\",\"url\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2\",\"name\":\"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620 - \u30dd\u30b1\u30b3\u30f3\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/09\\\/1757796067_og-base-w1200-v2.png\",\"datePublished\":\"2025-09-13T20:41:07+00:00\",\"author\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"breadcrumb\":{\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#breadcrumb\"},\"inLanguage\":\"ja\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#primaryimage\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/09\\\/1757796067_og-base-w1200-v2.png\",\"contentUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/09\\\/1757796067_og-base-w1200-v2.png\",\"width\":1200,\"height\":630},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/zenn.dev\\\/rgbkids\\\/articles\\\/e93e6e9ade48f2#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u30db\u30fc\u30e0\",\"item\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\",\"name\":\"\u30dd\u30b1\u30b3\u30f3\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"ja\"},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\",\"name\":\"info@pokecon.jp\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"caption\":\"info@pokecon.jp\"},\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/author\\\/infopokecon-jp\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620 - \u30dd\u30b1\u30b3\u30f3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2","og_locale":"ja_JP","og_type":"article","og_title":"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620 - \u30dd\u30b1\u30b3\u30f3","og_description":"VTeacher\u6240\u5c5e\u306eSatoko\u3067\u3059\uff01\u666e\u6bb5\u306f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3092\u30e1\u30a4\u30f3\u3068\u3057\u3066\u3001QA\u7684\u306a\u3053\u3068\u3084\u9032\u6357\u7ba1\u7406\u306a\u3069\u3001\u3044\u308d\u3044\u308d\u3084\u3063\u3066\u3044\u307e\u3059\u3002\u6700\u8fd1\u306e\u8da3\u5473\u306fAI\u3068\u306e\u304a\u3057\u3083\u3079\u308a\u3067\u3059\uff01 \u3068\u3053\u308d\u3067\uff01 \u305b\u3063\u304b\u304fFigma\u306bMCP\u30b5\u30fc\u30d0\u30fc\u304c\u3042\u308b\u306e\u306b [&hellip;]","og_url":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2","og_site_name":"\u30dd\u30b1\u30b3\u30f3","article_published_time":"2025-09-13T20:41:07+00:00","og_image":[{"width":1200,"height":630,"url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/09\/1757796067_og-base-w1200-v2.png","type":"image\/png"}],"author":"info@pokecon.jp","twitter_card":"summary_large_image","twitter_misc":{"\u57f7\u7b46\u8005":"info@pokecon.jp","\u63a8\u5b9a\u8aad\u307f\u53d6\u308a\u6642\u9593":"2\u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#article","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/5426\/"},"author":{"name":"info@pokecon.jp","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"headline":"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620","datePublished":"2025-09-13T20:41:07+00:00","mainEntityOfPage":{"@id":"https:\/\/pokecon.jp\/job\/5426\/"},"wordCount":160,"image":{"@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/09\/1757796067_og-base-w1200-v2.png","articleSection":["\u306f\u3066\u306a\u30d6\u30ed\u30b0"],"inLanguage":"ja"},{"@type":"WebPage","@id":"https:\/\/pokecon.jp\/job\/5426\/","url":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2","name":"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620 - \u30dd\u30b1\u30b3\u30f3","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/#website"},"primaryImageOfPage":{"@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#primaryimage"},"image":{"@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/09\/1757796067_og-base-w1200-v2.png","datePublished":"2025-09-13T20:41:07+00:00","author":{"@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"breadcrumb":{"@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#breadcrumb"},"inLanguage":"ja","potentialAction":[{"@type":"ReadAction","target":["https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2"]}]},{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#primaryimage","url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/09\/1757796067_og-base-w1200-v2.png","contentUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/09\/1757796067_og-base-w1200-v2.png","width":1200,"height":630},{"@type":"BreadcrumbList","@id":"https:\/\/zenn.dev\/rgbkids\/articles\/e93e6e9ade48f2#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u30db\u30fc\u30e0","item":"https:\/\/pokecon.jp\/job\/"},{"@type":"ListItem","position":2,"name":"\u3042\u308b\u3079\u304d\u5834\u6240\u306b\u5e30\u308d\u3046\uff01ReAct\u306b\u7acb\u3061\u8fd4\u308aClaude Code + Playwright MCP + Figma MCP\u3067\u30c7\u30b6\u30a4\u30f3\u3092\u53cd\u6620"}]},{"@type":"WebSite","@id":"https:\/\/pokecon.jp\/job\/#website","url":"https:\/\/pokecon.jp\/job\/","name":"\u30dd\u30b1\u30b3\u30f3","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/pokecon.jp\/job\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"ja"},{"@type":"Person","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997","name":"info@pokecon.jp","image":{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","caption":"info@pokecon.jp"},"url":"https:\/\/pokecon.jp\/job\/author\/infopokecon-jp\/"}]}},"_links":{"self":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/5426","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/comments?post=5426"}],"version-history":[{"count":1,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/5426\/revisions"}],"predecessor-version":[{"id":5428,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/5426\/revisions\/5428"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media\/5427"}],"wp:attachment":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media?parent=5426"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/categories?post=5426"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/tags?post=5426"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}