第一周第二課筆記-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 ()
}
const form = useForm<z.infer<typeof formSchema>>({
resolver: zodResolver(formSchema),
defaultValues: {
github_account_name: "",
},
})
function onSubmit(values: z.infer<typeof formSchema>) {
// 將會在 console 顯示提交的內容
console.log(values)
}
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>
)
npm run dev
http://localhost:3000/
{github_account_name: 'YEUNG'}

如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!
作者暂未设置收款二维码