App下載

5分鐘實(shí)現(xiàn)網(wǎng)站復(fù)刻:AI助力前端開(kāi)發(fā)

來(lái)源: 豆包MarsCode 2024-12-19 16:55:03 瀏覽數(shù) (782)
反饋

原標(biāo)題:只需5分鐘,水靈靈地實(shí)現(xiàn)網(wǎng)站復(fù)刻!

作為前端開(kāi)發(fā)者,我們的日常工作中總是有各種各樣的 UI 布局任務(wù)。從設(shè)計(jì)稿到代碼實(shí)現(xiàn),往往需要花費(fèi)大量時(shí)間去調(diào)整布局、優(yōu)化細(xì)節(jié),這種重復(fù)性的工作不僅浪費(fèi)時(shí)間資源,還無(wú)形中加重了我們的工作負(fù)荷,讓人感到疲憊。???

前段時(shí)間,我在 GitHub 上偶然發(fā)現(xiàn)了一個(gè)熱門(mén)的開(kāi)源項(xiàng)目 Screenshot-to-Code,它能夠通過(guò) AI 自動(dòng)生成前端代碼,并且支持生成多種不同技術(shù)棧的代碼,如 HTML + TailwindReact + Tailwind 等等。

Screenshot-to-Code

想到可以借助 AI 來(lái)幫助我開(kāi)發(fā)復(fù)雜的頁(yè)面,我立刻決定嘗試一下。

環(huán)境搭建

首先,我們可以將項(xiàng)目 Clone 到本地并用 IDE 打開(kāi),準(zhǔn)備本地部署啟動(dòng)。然而,面對(duì)冗長(zhǎng)的項(xiàng)目 Readme 文檔,直接閱讀可能會(huì)帶來(lái)很重的視覺(jué)負(fù)擔(dān)。

IDE.png

這個(gè)時(shí)候我想到,我剛好有安裝豆包MarsCode 編程助手插件,決定嘗試下能否讓 AI 告訴我該如何進(jìn)行部署。在向 AI 助手提問(wèn)之后,它立刻按照步驟指引我,需要先進(jìn)入后端目錄執(zhí)行哪些命令,再進(jìn)入前端目錄執(zhí)行哪些命令。

豆包MarsCode 編程助手插件

按照它給到的命令執(zhí)行后,我成功地啟動(dòng)了項(xiàng)目:

Screenshot-to-Code啟動(dòng)界面

但項(xiàng)目只支持 GPT 和 Claude 的 API,這些 API 都要收費(fèi),我只想用免費(fèi)的 Gemini 模型,要怎么修改呢?

使用編程助手增加 Gemini 模型

首先,我找到模型配置的代碼 model.ts,當(dāng)我在注釋上寫(xiě)了需要增加 Gemini 模型后,編程助手立刻就幫我生成了代碼,我只需要按下 TAB 鍵采納即可。

編程助手增加 Gemini 模型1

編程助手增加 Gemini 模型2

接著在 backend/.env、backend/config.py 增加 Gemini 的 API KEY:

#.env增加
keyGEMINI_API_KEY=xxxxxx


#config.py增加獲取key
GEMINI_API_KEY = os.environ.get("GEMINI_API_KEY", None)

然后可以在Llm.py 中增加 Gemini 模型以及調(diào)用 Gemini 的代碼。這時(shí)我發(fā)現(xiàn)有一個(gè) stream_claude_response_native 方法,看起來(lái)是在調(diào)用 Claude,我們讓豆包MarsCode 編程助手解釋一下:

MarsCode 編程助手解釋

通過(guò)豆包MarsCode 編程助手的解釋,確認(rèn)是在調(diào)用 Claude。那我們需要增加調(diào)用 Gemini 的代碼。編寫(xiě)代碼過(guò)程中,通過(guò)編程助手提供的代碼補(bǔ)全功能,效率獲得了顯著的提升。

class Llm(Enum):
    GPT_4_VISION = "gpt-4-vision-preview"
    GPT_4_TURBO_2024_04_09 = "gpt-4-turbo-2024-04-09"
    GPT_4O_2024_05_13 = "gpt-4o-2024-05-13"
    CLAUDE_3_SONNET = "claude-3-sonnet-20240229"
    CLAUDE_3_OPUS = "claude-3-opus-20240229"
    CLAUDE_3_HAIKU = "claude-3-haiku-20240307"
    CLAUDE_3_5_SONNET_2024_06_20 = "claude-3-5-sonnet-20240620"
    //新增gemini
    GEMINI_1_5_PRO_LATEST = "gemini-1.5-pro-latest"

    

    
async def stream_gemini_response(
    messages: List[ChatCompletionMessageParam],
    api_key: str,
    callback: Callable[[str], Awaitable[None]],
) -> str:
  genai.configure(api_key=api_key)

  
  generation_config = genai.GenerationConfig(
    temperature = 0.0
  )
  model = genai.GenerativeModel(
    model_name = "gemini-1.5-pro-latest",
    generation_config = generation_config
  )
  contents = parse_openai_to_gemini_prompt(messages);

  
  response = model.generate_content(
    contents = contents,
    #Support streaming
    stream = True,
   )

   
  for chunk in response:
    content = chunk.text or ""
    await callback(content)


  if not response:
    raise Exception("No HTML response found in AI response")
  else:
    return response.text;


def parse_openai_to_gemini_prompt(prompts):
    messages = []
    for prompt in prompts:
        message = {}
        message['role'] = prompt['role']
        if prompt['role'] == 'system':
            message['role'] = 'user'
        if prompt['role'] == 'assistant':
            message['role'] = 'model'
        message['parts'] = []
        content = prompt['content']
        if isinstance(content, list):
            for content in prompt['content']:
                part = {}
                if content['type'] == 'image_url':
                    base64 = content['image_url']['url']
                    part['inline_data'] = {
                        'data': base64.split(",")[1],
                        'mime_type': base64.split(";")[0].split(":")[1]
                    }
                elif content['type'] == 'text':
                    part['text'] = content['text']
                message['parts'].append(part)
        else:
            message['parts'] = [content]
        messages.append(message)
    return messages

寫(xiě)完代碼之后,我們可以使用【注釋代碼】功能給代碼加上注釋,讓代碼更加規(guī)范:

MarsCode 編程助手注釋代碼

之后,我們還需要在 generate_code 增加調(diào)用前面寫(xiě)的 Gemini 方法:



if validated_input_mode == "video":
                if not anthropic_api_key:
                    await throw_error(
                        "Video only works with Anthropic models. No Anthropic API key found. Please add the environment variable ANTHROPIC_API_KEY to backend/.env or in the settings dialog"
                    )
                    raise Exception("No Anthropic key")


                completion = await stream_claude_response_native(
                    system_prompt=VIDEO_PROMPT,
                    messages=prompt_messages,  # type: ignore
                    api_key=anthropic_api_key,
                    callback=lambda x: process_chunk(x),
                    model=Llm.CLAUDE_3_OPUS,
                    include_thinking=True,
                )
                exact_llm_version = Llm.CLAUDE_3_OPUS
            elif (
                code_generation_model == Llm.CLAUDE_3_SONNET
                or code_generation_model == Llm.CLAUDE_3_5_SONNET_2024_06_20
            ):
                if not anthropic_api_key:
                    await throw_error(
                        "No Anthropic API key found. Please add the environment variable ANTHROPIC_API_KEY to backend/.env or in the settings dialog"
                    )
                    raise Exception("No Anthropic key")


                completion = await stream_claude_response(
                    prompt_messages,  # type: ignore
                    api_key=anthropic_api_key,
                    callback=lambda x: process_chunk(x),
                    model=code_generation_model,
                )
                exact_llm_version = code_generation_model
            # 增加調(diào)用gemini
            elif (           
                code_generation_model == Llm.GEMINI_1_5_PRO_LATEST
            ):
                if not GEMINI_API_KEY:
                    await throw_error(
                        "No GEMINI API key found. Please add the environment variable ANTHROPIC_API_KEY to backend/.env or in the settings dialog"
                    )
                    raise Exception("No GEMINI key")


                completion = await stream_gemini_response(
                    prompt_messages,  # type: ignore
                    api_key=GEMINI_API_KEY,
                    callback=lambda x: process_chunk(x),
                )
                exact_llm_version = code_generation_model

            
            else:
                completion = await stream_openai_response(
                    prompt_messages,  # type: ignore
                    api_key=openai_api_key,
                    base_url=openai_base_url,
                    callback=lambda x: process_chunk(x),
                    model=code_generation_model,
                )
                exact_llm_version = code_generation_model

最后安裝 Gemini SDK:

cd backend
poetry add google-generativeai

效果呈現(xiàn)

改完所有代碼再啟動(dòng)項(xiàng)目后,就可以看到已經(jīng)有 Gemini 模型啦,讓我們來(lái)試試效果:?

我們上傳豆包MarsCode 官網(wǎng)截圖,點(diǎn)擊生成后,右側(cè)即為 AI 生成的效果,可以看到還原度還不錯(cuò)。

豆包MarsCode 官網(wǎng)截圖.png

由于自動(dòng)生成的字體沒(méi)有漸變色的效果,我們可以通過(guò)給 AI 提要求,增加漸變色效果,可以明顯看到,在漸變色字體的設(shè)計(jì)下頁(yè)面的視覺(jué)效果更加高級(jí)了!?

豆包MarsCode 編程助手復(fù)刻官網(wǎng)

豆包MarsCode 編程助手的幫助下,我們?cè)陧?xiàng)目上增加了免費(fèi)了 Gemini 模型。有了它,項(xiàng)目開(kāi)發(fā)更加高效便捷了,官網(wǎng)復(fù)刻,輕松拿下!

大家趕快來(lái)嘗試一下吧!

1 人點(diǎn)贊