水分子社區(HOH)前端共學營 - 筆記(3)

第一周第二課筆記-ShadcnUI的使用(建立表格的例子)

第一周第二課筆記 - Shadcn UI 的使用 (建立表格的例子) 如果有看了上一篇的介紹,也看了一個簡單示例,相信大家對 Shadcn 都有初步了解。 事不宜遲,馬上教大家利用 Shadcn 和其他工具做一個簡單的表格。 而這個表格會配合 useForm 結合 zod 的運用。

背景:

假設已創建一個項目,相關步驟可參看上一篇文章 - 水分子社區(HOH)前端共學營 - 筆記(2) 的教學

安裝部分:

  1. 需要用到 shadcn 中 form 的元件,要執行一個安裝指令。
    npx shadcn@latest add form
  2. 需要用到 zod schema 來進行表單驗證,因此會利用 zodResolver 作為 useForm 的 resolver,所以要安裝 hookform/resolvers。
    npm i @hookform/resolvers
  3. 需要使用 zod,它是以 TS 為主的型別聲明和驗證的庫。
    npm i zod

創建部分:

  1. 在 app 文件夾下創建一個新文件,名為 HohForm.tsx

引用部分:

"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 的格式

  1. 建立 export function HohForm() {}
    
    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. 打開頁面

http://localhost:3000/


3. 打開開發人員工具的"console",然後在頁面的框內輸入你的 github 用戶名稱,如下圖所示:
例子: 在輸入"YEUNG"後,然後按"提交",就可以在 console 即時查看的結果。

{github_account_name: 'YEUNG'}


![螢幕擷取畫面 2025-01-30 224628.png](https://img.learnblockchain.cn/attachments/2025/01/M2Vbhiaj679b90d94a18d.png)
  • 原创
  • 学分: 0
  • 分类: Sui
  • 标签: HOH 
点赞 0
收藏 0
分享
本文参与登链社区写作激励计划 ,好文好收益,欢迎正在阅读的你也加入。

0 条评论

请先 登录 后评论
楊景輝
楊景輝
杨景辉 香港城市大学 硕士 专长: 计算机编程(全栈工程师)、区块链开发、算法研究、数据库设计、项目管理