第一周第二課筆記-ShadcnUI的使用(建立表格的例子)
第一周第二課筆記 - Shadcn UI 的使用 (建立表格的例子) 如果有看了上一篇的介紹,也看了一個簡單示例,相信大家對 Shadcn 都有初步了解。 事不宜遲,馬上教大家利用 Shadcn 和其他工具做一個簡單的表格。 而這個表格會配合 useForm 結合 zod 的運用。
假設已創建一個項目,相關步驟可參看上一篇文章 - 水分子社區(HOH)前端共學營 - 筆記(2) 的教學
npx shadcn@latest add form
npm i @hookform/resolvers
npm i zod
"use client"
import { zodResolver } from "@hookform/resolvers/zod"
import { useForm } from "react-hook-form"
import { z } from "zod"
import { Button } from "@/components/ui/button"
import {
Form,
FormControl,
FormDescription,
FormField,
FormItem,
FormLabel,
FormMessage,
} from "@/components/ui/form"
import { Input } from "@/components/ui/input"
1.使用 z.object 建立 Obejct Schema
const formSchema = z.object({
github_account_name: z.string().min(5, {
message: "github 用戶名稱 必須至少有5個數字或英文",
}),
})
z.string().min(5, { xxx }): 字串的最小長度為 5 message: "github 用戶名稱 必須至少有5個數字或英文: 如未達到要求會返回這個錯誤提示 z.infer: 會將 schema 轉為 type 的格式
export function HohForm() {
/**/
return ()
}
3. 定義表格內容
const form = useForm<z.infer<typeof formSchema>>({
resolver: zodResolver(formSchema),
defaultValues: {
github_account_name: "",
},
})
4. 定義提交功能
function onSubmit(values: z.infer<typeof formSchema>) {
// 將會在 console 顯示提交的內容
console.log(values)
}
5. 建構 return 部分
return ( <Form {...form}> <form onSubmit={form.handleSubmit(onSubmit)} className="space-y-8"> <FormField control={form.control} name="github_account_name" render={({ field }) => ( <FormItem> <FormLabel>github 用戶名稱</FormLabel> <FormControl> <Input placeholder="HOH frontend" {...field} /> </FormControl> <FormDescription> 請在上方輸入你的 github 用戶名稱 </FormDescription> <FormMessage /> </FormItem> )} /> <Button type="submit">提交</Button> </form> </Form> )
## 測試部分:
1. 啟動項目
npm run dev
2. 打開頁面
3. 打開開發人員工具的"console",然後在頁面的框內輸入你的 github 用戶名稱,如下圖所示:
例子: 在輸入"YEUNG"後,然後按"提交",就可以在 console 即時查看的結果。
{github_account_name: 'YEUNG'}
![螢幕擷取畫面 2025-01-30 224628.png](https://img.learnblockchain.cn/attachments/2025/01/M2Vbhiaj679b90d94a18d.png)
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!