App下載

用 AI 一小時(shí)重構(gòu)代碼:豆包 MarsCode 實(shí)戰(zhàn)教程

來源: 豆包MarsCode 2025-01-23 18:09:45 瀏覽數(shù) (252)
反饋

相信程序員朋友們都遇到過這個(gè)問題:項(xiàng)目的演進(jìn)過程中,代碼往往會不斷堆砌,如果缺乏對代碼質(zhì)量的關(guān)注,它會不可避免地走向混亂,逐漸演變成邏輯復(fù)雜、難以維護(hù)的“祖?zhèn)鞔a”,想優(yōu)化它但無從下手~

豆包 MarsCode AI 編程云課堂 「進(jìn)階開發(fā)實(shí)戰(zhàn)系列」特邀【字節(jié)資深前端姚路行老師】為大家?guī)?strong>代碼重構(gòu)實(shí)戰(zhàn)課程,幫助大家提升代碼質(zhì)量,提升項(xiàng)目可維護(hù)性,讓開發(fā)過程更加輕松高效~

課前準(zhǔn)備

下載并安裝豆包 MarsCode

在官網(wǎng)下載并安裝好豆包MarsCode 插件:

豆包MarsCode 插件

克隆項(xiàng)目

本課程使用 AI 以 Next.js 框架生成的一個(gè) todolist 項(xiàng)目

git clone https://github.com/ylx911229/todo-list_back.git

使用“code”命令來啟動(dòng) Visual Studio Code 并將其打開

cd todo-list_back 
code .

克隆項(xiàng)目

安裝依賴

npm i

啟動(dòng)項(xiàng)目

npm run dev

  • 項(xiàng)目依賴 Node.js 版本大于18.18.0,啟動(dòng)前確認(rèn)好本地 Node.js 版本,版本過低可在 Node.js 官網(wǎng)下載安裝

本地預(yù)覽

打開瀏覽器,訪問:http://localhost:3000,運(yùn)行成功得到如下效果

本地預(yù)覽

課程內(nèi)容

組件拆分

首先我們先讓豆包 MarsCode 幫我們創(chuàng)建一個(gè) components 目錄,用于存放拆分出的組件,豆包 MarsCode 還貼心的告訴我們需要改 tailwind.config.ts 添加 components 目錄,Tailwind CSS 就會掃描目錄下的文件,以便應(yīng)用相應(yīng)的樣式。

Workspace在app目錄下創(chuàng)建components目錄

豆包 MarsCode組件拆分1

豆包 MarsCode組件拆分2

接下來讓豆包MarsCode 幫我們將項(xiàng)目合理拆分組件

豆包 MarsCode組件拆分3

豆包 MarsCode組件拆分4

豆包 MarsCode組件拆分5

豆包 MarsCode組件拆分6

如果由于輸出 token 長度限制,拆分的組件沒有輸出完全的話,可以讓豆包MarsCode 繼續(xù)輸出

Workspace 拆分出的組件沒有輸出完成,請繼續(xù)輸出

豆包 MarsCode組件拆分7

最后修改主文件,將主文件改寫成對子組件的引入

Workspace 將主文件改寫成對子組件的引入

豆包 MarsCode組件拆分8

資源抽離

類型聲明的抽離,單獨(dú)文件管理類型更清晰可讀,另外,項(xiàng)目當(dāng)中也會有很多可以多組件,多文件復(fù)用的常量,抽離出來統(tǒng)一管理,一處修改,多處受益

類型聲明抽離

首先將主文件中的類型聲明單獨(dú)抽離一個(gè)文件

Workspace 將主文件中的類型聲明單獨(dú)抽離一個(gè)文件

豆包 MarsCode類型聲明抽離1

接下來修改項(xiàng)目中所有文件對類型聲明的引入方式以及引入路徑

 Workspace 修改項(xiàng)目中所有文件對類型聲明的引入方式以及引入路徑

豆包 MarsCode類型聲明抽離2

常量抽離

單獨(dú)抽離項(xiàng)目中的常量,并修改項(xiàng)目中所有文件對常量的引入方式以及引入路徑(輸出簡單的話,也可以在一條指令中引導(dǎo)豆包MarsCode 完成)

 Workspace 將項(xiàng)目中的常量單獨(dú)抽離一個(gè)文件,并修改項(xiàng)目中所有文件對常量的引入方式以及引入路徑

豆包MarsCode常量抽離1

豆包MarsCode常量抽離2

狀態(tài)管理優(yōu)化

當(dāng)項(xiàng)目中一個(gè)組件內(nèi)管理過多的狀態(tài)時(shí),代碼會非常亂,并且可讀性很差,我們可以根據(jù)狀態(tài)的不同類型,去抽離獨(dú)立的自定義 hooks ,讓代碼更加可讀可維護(hù),而當(dāng)狀態(tài)管理需要組件層層傳遞時(shí),更好的做法就是將狀態(tài)管理提升為全局狀態(tài)管理,兩種都是對狀態(tài)管理的優(yōu)化,選擇更適合自己項(xiàng)目的方式

自定義hooks

將兩個(gè)狀態(tài)管理作為自定義 hooks 單獨(dú)抽離,并改寫主文件對他們的引入

Workspace 將從localStorage加載todos和保存todos到localStorage做為useLoadTodosFromLocalStorage和useSaveTodosFromLocalStorage兩個(gè)自定義hooks單獨(dú)抽離,并改寫主文件對他們的引入

豆包MarsCode自定義hooks1

豆包MarsCode自定義hooks2

全局狀態(tài)管理

將項(xiàng)目中的狀態(tài)管理改為全局狀態(tài)管理,主文件以及所有組件通過全局狀態(tài)獲取而不是通過 props 傳遞

Workspace 將項(xiàng)目中的狀態(tài)管理改為全局狀態(tài)管理,主文件以及所有組件通過全局狀態(tài)獲取而不是通過props傳遞

豆包MarsCode全局狀態(tài)管理1

豆包MarsCode全局狀態(tài)管理2

豆包MarsCode全局狀態(tài)管理3

代碼提交

最后我們提交代碼時(shí),可以讓豆包MarsCode 幫我們總結(jié)一下改動(dòng),給一個(gè)合適的commit message

豆包MarsCode代碼提交1

豆包MarsCode代碼提交2

在本次課程中,我們了解到合理重構(gòu)代碼的思路,以及如何通過豆包 MarsCode 一步步對已有代碼進(jìn)行重構(gòu),最終完成項(xiàng)目的代碼重構(gòu)。相信聽完課的你都能有所收獲并嘗試付諸實(shí)踐,提高自己的代碼質(zhì)量以及開發(fā)效率。

點(diǎn)擊??【豆包 MarsCode 官網(wǎng)】立即體驗(yàn) AI 編程吧~

0 人點(diǎn)贊