精品国产av一区二区三区,国产av一区二区三区,丰满少妇大乳高潮在线,9lporm自拍视频区九色

當(dāng)前位置:首頁(yè) > 最新資訊 > 行業(yè)資訊

大模型下B端前端代碼輔助生成的思考與實(shí)踐

一、背景

重復(fù)工作,代碼規(guī)范:B端前端代碼開(kāi)發(fā)過(guò)程中開(kāi)發(fā)者總會(huì)面臨重復(fù)開(kāi)發(fā)的痛點(diǎn),很多CRUD頁(yè)面的元素模塊基本相似,但仍需手動(dòng)開(kāi)發(fā),將時(shí)間花在簡(jiǎn)單的元素搭建上,降低了業(yè)務(wù)需求的開(kāi)發(fā)效率,同時(shí)因?yàn)椴煌_(kāi)發(fā)者的代碼風(fēng)格不一致,使得敏捷迭代時(shí)其他人上手成本較高。

AI代替簡(jiǎn)單腦力:AI大模型的不斷發(fā)展,已經(jīng)具備簡(jiǎn)單的理解能力,并可以進(jìn)行語(yǔ)言到指令的轉(zhuǎn)換。對(duì)于基礎(chǔ)頁(yè)面搭建這樣的通用指令可以滿(mǎn)足日?;A(chǔ)頁(yè)面搭建的需要,提升通用場(chǎng)景業(yè)務(wù)開(kāi)發(fā)效率。

二、生成鏈路一覽

B端頁(yè)面列表、表單、詳情都支持生成,鏈路大概可分為以下幾個(gè)步驟。

圖片

輸入自然語(yǔ)言

結(jié)合大模型按照指定規(guī)則提取出相應(yīng)搭建信息

搭建信息結(jié)合代碼模板與AST輸出前端代碼

三、表達(dá)需求

圖形化配置

輔助代碼生成第一步是告訴它開(kāi)發(fā)出怎樣的界面,提到這里,我們首先想到的是頁(yè)面配置,即目前主流的低代碼產(chǎn)品形式,用戶(hù)通過(guò)一系列的圖形化配置對(duì)頁(yè)面進(jìn)行搭建,如下圖:

圖片

以上配置方式對(duì)于通用場(chǎng)景(如后臺(tái)邏輯較為簡(jiǎn)單的CURD頁(yè)面)或是特定的業(yè)務(wù)場(chǎng)景(如會(huì)場(chǎng)搭建)有較好的提效作用 。而對(duì)于需要不斷迭代邏輯相對(duì)復(fù)雜的需求來(lái)說(shuō),由于是通過(guò)圖形化操作的方式進(jìn)行配置,對(duì)于交互設(shè)計(jì)要求較高,并且具備一定的上手成本,并且隨著需求的復(fù)雜度越來(lái)越高,配置表單交互越來(lái)越復(fù)雜,維護(hù)成本也越來(lái)越高。因此,頁(yè)面配置的方式前端領(lǐng)域的使用是相對(duì)克制的。

AI直接生成代碼

AI生成代碼在工具函數(shù)場(chǎng)景下應(yīng)用較多,但對(duì)于公司內(nèi)部特定業(yè)務(wù)場(chǎng)景的需求,可能需要考慮以下幾點(diǎn):

生成定制化:公司團(tuán)隊(duì)內(nèi)部有自己的技術(shù)棧與重型通用組件,需要將這些知識(shí)進(jìn)行預(yù)訓(xùn)練,目前對(duì)于長(zhǎng)文本的預(yù)訓(xùn)練內(nèi)容僅支持單次會(huì)話(huà)注入,token數(shù)消耗較高;

準(zhǔn)確度:AI生成代碼的準(zhǔn)確度挑戰(zhàn)是比較大的,加上預(yù)訓(xùn)練包含大段prompt,因?yàn)榇a輸出的內(nèi)容細(xì)節(jié)過(guò)多,加上模型幻覺(jué),目前來(lái)看業(yè)務(wù)代碼的失敗率是較高的,而準(zhǔn)確度是考量輔助編碼的核心指標(biāo),如果這一點(diǎn)無(wú)法解決,輔助編碼效果將大打折扣;

生成內(nèi)容殘缺:由于GPT單次會(huì)話(huà)的存在限制,對(duì)于復(fù)雜需求,代碼生成有一定幾率被截?cái)?,影響生成成功率?/p>

自然語(yǔ)言轉(zhuǎn)指令

GPT其實(shí)還有個(gè)很重要的能力,那就是自然語(yǔ)言轉(zhuǎn)指令,指令即行動(dòng),舉個(gè)例子:我們假設(shè)一個(gè)函數(shù)方法實(shí)現(xiàn),輸入是自然語(yǔ)言,結(jié)合GPT與內(nèi)置的prompt,讓其穩(wěn)定的輸出某幾個(gè)單詞,我們是不是就可以通過(guò)對(duì)這些單詞輸出做出進(jìn)一步的行動(dòng)?這相對(duì)于圖形化配置有以下幾個(gè)優(yōu)點(diǎn):

學(xué)習(xí)門(mén)檻低:因?yàn)樽匀徽Z(yǔ)言本身就是人類(lèi)的原生語(yǔ)言,你只需要根據(jù)你的想法描述頁(yè)面即可,當(dāng)然描述的內(nèi)容是需要遵循一些規(guī)范的,但相對(duì)于圖形化配置來(lái)說(shuō)效率是有明顯提升的;

復(fù)雜度黑盒:圖形化配置的復(fù)雜度會(huì)隨著配置頁(yè)面復(fù)雜度的上升而上升,而這樣的復(fù)雜度會(huì)一覽無(wú)余地展示在用戶(hù)面前,用戶(hù)可能會(huì)迷失在復(fù)雜的配置頁(yè)面交互中,配置成本逐步上升;

敏捷迭代:如果要在用戶(hù)端新增一個(gè)頁(yè)面配置功能,基于大模型的交互方式可能只需要新增幾個(gè)prompt,但圖形化配置需要開(kāi)發(fā)復(fù)雜表單以便于快速輸入。

    這里大家可能會(huì)有個(gè)疑問(wèn):

    生成的指令信息不也會(huì)出現(xiàn)大模型幻覺(jué)嗎?如何保證每次生成指令信息是穩(wěn)定且一致的呢?

    自然語(yǔ)言轉(zhuǎn)指令可行大致有以下幾個(gè)原因:

    由長(zhǎng)文本轉(zhuǎn)關(guān)鍵信息屬于總結(jié)內(nèi)容,大模型在總結(jié)場(chǎng)景下的準(zhǔn)確度遠(yuǎn)高于擴(kuò)散型場(chǎng)景;

    由于指令信息只是提取需求中的關(guān)鍵信息,不需要做代碼技術(shù)棧上的預(yù)訓(xùn)練,因此prompt存在很大的可優(yōu)化空間,通過(guò)優(yōu)化完善prompt內(nèi)容可以有效提升輸出準(zhǔn)確度;

    準(zhǔn)確性可驗(yàn)證,對(duì)于每一個(gè)場(chǎng)景不同表述需求輸入,可以通過(guò)單測(cè)預(yù)測(cè)輸出驗(yàn)證準(zhǔn)確性,當(dāng)出現(xiàn)badCase,我們?cè)趦?yōu)化后針對(duì)該badCase接入單測(cè)。保證準(zhǔn)確度不斷提高。

      讓我們來(lái)看最終的信息轉(zhuǎn)化結(jié)果:

      對(duì)于代碼輔助來(lái)說(shuō),基于用戶(hù)的需求描述,經(jīng)過(guò)PROMPT處理,可以拿到這樣的信息。為代碼生成提供基礎(chǔ)信息。

      圖片

      四、信息轉(zhuǎn)化為代碼

      通過(guò)大模型拿到自然語(yǔ)言對(duì)應(yīng)可編碼的信息(即上面例子中的JSON)后,我們就可以基于這個(gè)信息轉(zhuǎn)化代碼了。對(duì)于一個(gè)有明確場(chǎng)景的頁(yè)面而言,一般情況下可分為主代碼模板(列表、表單、描述框架)+ 業(yè)務(wù)組件。

      轉(zhuǎn)化流程

      圖片

      我們?nèi)绾伍_(kāi)發(fā)代碼的?

      其實(shí)這一步很像我們自己開(kāi)發(fā)代碼,我們拿到需求后,大腦中會(huì)提取其中的關(guān)鍵信息,即上方提到的自然語(yǔ)言轉(zhuǎn)指令,然后我們會(huì)在vscode中創(chuàng)建一個(gè)文件,然后會(huì)進(jìn)行以下操作:

      首先一定是創(chuàng)建代碼模板,然后根據(jù)場(chǎng)景引入對(duì)應(yīng)重型組件,如列表就引入ProTable,表單就引入ProForm。

      基于ProTable等重型組件并向其中添加一些屬性,如headerTitle、pageSize等列表相關(guān)信息。

      根據(jù)需求描述引入組件,比如識(shí)別到篩選項(xiàng)中存在類(lèi)目選擇,會(huì)在useColumns新增業(yè)務(wù)組件,識(shí)別到需求描述中存在導(dǎo)入導(dǎo)出組件,會(huì)在頁(yè)面的指定位置新增導(dǎo)入導(dǎo)出業(yè)務(wù)組件。

      拿到mock鏈接,新增請(qǐng)求層,在頁(yè)面指定位置引入。

      對(duì)于以上常用的代碼插入場(chǎng)景都可以封裝進(jìn)JSON中,然后通過(guò)代碼模板結(jié)合AST插入或字符串模板替換的方式生成對(duì)應(yīng)代碼。

      五、源碼生成

      定位

      源碼輔助主要幫助開(kāi)發(fā)者減少重復(fù)的工作,提升編碼效率,和低代碼頁(yè)面搭建屬于完全不同的賽道,低代碼重在特定場(chǎng)景下搭建完整的頁(yè)面,并且頁(yè)面功能數(shù)量是可枚舉的,業(yè)界低代碼搭建也有很優(yōu)秀的實(shí)踐。而源碼輔助工具旨在幫助用戶(hù)盡可能多的初始化業(yè)務(wù)需求代碼,后面的修改維護(hù)在代碼層面交給用戶(hù),提升新增頁(yè)面的開(kāi)發(fā)效率。

      具體的功能架構(gòu)見(jiàn)下方:

      圖片

      六、組件向量搜索與嵌入

      對(duì)于前端開(kāi)發(fā)來(lái)說(shuō),提效的本質(zhì)是少開(kāi)發(fā)代碼,更快的頁(yè)面生成是一方面,良好的組件抽離是相當(dāng)重要的一環(huán),我們結(jié)合向量對(duì)組件的引入鏈路進(jìn)行了優(yōu)化,在初始化模板與存量代碼中快速搜索定位組件。

      組件向量引入鏈路

      圖片

      組件信息錄入

      支持快速獲取組件的描述內(nèi)容與組件引入范式,一鍵錄入組件,組件描述會(huì)轉(zhuǎn)化為向量數(shù)據(jù)存入向量數(shù)據(jù)庫(kù)。

      圖片

      組件向量搜索

      用戶(hù)輸入描述后,會(huì)將描述轉(zhuǎn)化為向量,基于余弦相似度與組件列表進(jìn)行比對(duì),找到相似度最高的組件TOP N。

      圖片

      組件快速插入

      用戶(hù)可以在存量代碼中快速通過(guò)描述搜索匹配度最高的組件,回車(chē)進(jìn)行插入。

      圖片

      七、未來(lái)展望

      組件嵌入模板:目前組件已支持向量搜索,通過(guò)結(jié)合源碼頁(yè)面生成,支持動(dòng)態(tài)匹配組件并嵌入模板;

      存量代碼的編輯生成:目前僅支持新增頁(yè)面的源碼生成,后續(xù)將支持存量頁(yè)面的局部代碼新增;

      代碼模板流水線(xiàn):AST的代碼操作工具化,將自然語(yǔ)言與代碼寫(xiě)入進(jìn)一步打通,提升場(chǎng)景拓展效率。

      猜你喜歡