AI Agent系列(八) -基于ReAct架构的前端开发助手(DeepSeek)

打印 上一主题 下一主题

主题 1607|帖子 1607|积分 4821


项目目的

开发一个可以大概协助HTML+JS+CSS前端设计的AI Agent,通过在网页中输入相应的问题,此应用能自动天生对应的html文件设计的前端程序,并通过flask架构下实现自动跳转到对应界面来完成功能验证。
一、核心功能设计

AI Agent应该具备以下能力:


  • 根据天然语言形貌天生前端代码
  • 分析现有代码并提供优化建议
  • 回答前端相干问题
  • 自动修复常见错误
二、技能栈选择



  • 语言模子: DeepSeek
  • 开发框架: Flask
  • 前端交互: html +CSS +JS
三、Python实现

3.1 设置基础情况

必要安装的工具包包罗LLM的API工具包openai,网页应用开发框架flask,dot的python情况python-dotenv,Json文件解析json。
  1. # 安装必要库
  2. pip install openai flask python-dotenv requests json
复制代码
3.2 界说AI前端天生的类

在这个类库中,必要考虑如下功能的实现:

  • 初始化,必要实现基于LLM的API的客户端初始化,基于ReAct架构的提示词;
  • 获取响应,基于LLM和体系提示词,用户输入的需求获取的响应信息;
  • 响应解析,解析基于ReAct架构的响应;
  • 天生html文件,基于响应的解析结果,天生html文件;
  1. import os
  2. from dotenv import load_dotenv
  3. from datetime import datetime
  4. from flask import Flask, request, render_template
  5. from openai import OpenAI
  6. import json
  7. load_dotenv()
  8. class DeepSeekAICodeAssistant:
  9.     def __init__(self):
  10.         self.api_key = os.getenv("DEEPSEEK_API_KEY")
  11.         self.base_url = "https://api.deepseek.com"
  12.         self.model = "deepseek-chat"
  13.         self.client = OpenAI(api_key=self.api_key, base_url=self.base_url)
  14.         self.context = []
  15.         self.system_prompt = """
  16.         你是一个专业的前端开发助手,采用ReAct(Reasoning+Acting)架构工作。
  17.         请按照以下JSON格式响应:
  18.         {
  19.             "thought": "分析...",
  20.             "action": "执行...",
  21.             "code": "生成的代码...",
  22.             "advice": "优化建议..."
  23.         }
  24.         """
  25.         self._init_context()
  26.     def _init_context(self):
  27.         """初始化对话上下文"""
  28.         self.context = [
  29.             {"role": "system", "content": self.system_prompt}
  30.         ]
  31.     def generate_response(self, user_input):
  32.         """
  33.         调用DeepSeek API生成响应
  34.         :param user_input: 用户输入
  35.         :return: 解析后的响应内容或错误信息
  36.         """
  37.         try:
  38.             self.context.append({"role": "user", "content": user_input})
  39.             response = self.client.chat.completions.create(
  40.                 model=self.model,
  41.                 messages=self.context,
  42.                 stream=False
  43.             )
  44.             assistant_reply = response.choices[0].message.content
  45.             self.context.append({"role": "assistant", "content": assistant_reply})
  46.             return self._parse_react_response(assistant_reply)
  47.         except (KeyError, json.JSONDecodeError) as e:
  48.             return {"error": f"响应解析失败: {str(e)}"}
  49.         except Exception as e:
  50.             return {"error": f"未知错误: {str(e)}"}
  51.     def _parse_react_response(self, response_text):
  52.         """解析ReAct格式的响应"""
  53.         try:
  54.             data = json.loads(response_text)
  55.             return {
  56.                 "thought": data.get("thought", "无"),
  57.                 "action": data.get("action", "无"),
  58.                 "code": data.get("code", "无代码生成"),
  59.                 "advice": data.get("advice", "无优化建议")
  60.             }
  61.         except json.JSONDecodeError:
  62.             return {
  63.                 "thought": "直接响应",
  64.                 "action": "生成代码",
  65.                 "code": response_text,
  66.                 "advice": ""
  67.             }
  68.     def generate_html_output(self, react_response, output_file="templates/output.html"):
  69.         """生成HTML输出文件,仅保存生成的代码"""
  70.         timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
  71.         # 只提取代码部分
  72.         generated_code = react_response.get('code', '无代码生成')
  73.         html_template = f"""<!DOCTYPE html>
  74.             <html>
  75.             <head>
  76.                 <title>AI前端助手 - {timestamp}</title>
  77.                 <style>
  78.                     body {{ font-family: Arial, sans-serif; margin: 20px; }}
  79.                     pre {{ background: #eee; padding: 10px; overflow-x: auto; }}
  80.                 </style>
  81.             </head>
  82.             <body>
  83.                 <h1>生成的响应式导航栏</h1>
  84.                 <pre>{generated_code}</pre>
  85.             </body>
  86.             </html>"""
  87.         os.makedirs(os.path.dirname(output_file), exist_ok=True)
  88.         with open(output_file, "w", encoding="utf-8") as f:
  89.             f.write(html_template)
  90.         return output_file
  91.         
复制代码
3.4 实例化

必要实例化flask和预界说的 DeepSeekAICodeAssistant
  1. # Flask应用
  2. app = Flask(__name__)
  3. assistant = DeepSeekAICodeAssistant()
复制代码
3.5 Flask路由

在路由中界说POST方法,当前端中输入了对应的需求后,将调用之前界说的获取响应和天生对应的html文件的功能。
当文件天生后,体系自动重定向到对应的文件举行代码的验证。
  1. @app.route("/", methods=["GET", "POST"])
  2. def index():
  3.     if request.method == "POST":
  4.         prompt = request.form.get("prompt")
  5.         if prompt:
  6.             result = assistant.generate_response(prompt)
  7.             if "error" not in result:
  8.                 assistant.generate_html_output(result)
  9.                 return render_template("output.html")
  10.             return f"<p style='color:red'>错误: {result['error']}</p>"
  11.     return """
  12.     <form method="POST">
  13.         <h2>DeepSeek前端助手</h2>
  14.         <textarea name="prompt" rows="5" cols="60" placeholder="输入你的前端需求..."></textarea><br>
  15.         <button type="submit">生成代码</button>
  16.     </form>
  17.     """
复制代码
3.6 主程序实行

至此,我们只必要通过main函数实行flask即可。
  1. if __name__ == "__main__":
  2.     app.run(debug=True)
复制代码
四、 功能测试

代码实行后,在浏览器输入如下地点:http://127.0.0.1:5000,输入需求-天生一个科学计算器。
点击代码天生后,体系将调转到天生的网页,举行功能测试。

AI Agent系列(八) -基于ReAct架构的前端开发助手(DeepSeek)

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

羊蹓狼

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表