วิธีสร้าง generic function สำหรับเครื่องมือ data validation ที่เป็นหลากหลายได้ใน typescript
วันนี้เราจะมาเรียนรู้วิธีการสร้างฟังก์ชั่นทั่วไปสำหรับเครื่องมือตรวจสอบข้อมูลใน TypeScript กันครับ!
ในรหัสนี้เราได้สร้างฟังก์ชั่นและประเภทข้อมูลที่ชื่อ AcceptedParser
ขึ้นมาก่อน ซึ่งสามารถรับข้อมูลชนิด T
และมีสองรูปแบบที่ยอมรับคือ:
ฟังก์ชั่นที่รับ input
และคืนค่าข้อมูลประเภท T
จากข้อมูลที่รับเข้ามา. อ็อบเจ็กต์ที่มีเมธอด parse
ที่รับ input
และคืนค่าข้อมูลประเภท T จากข้อมูลที่รับเข้ามา.
ขอบคุณ AcceptedParser จาก untypeable
;
หลังจากนั้นเราได้สร้างคลาส Entity
ซึ่งใช้สำหรับการจัดการข้อมูลของเรา
คลาสนี้ยังรับ schema
ที่เป็น AcceptedParser
ใน constructor ของมันด้วย และมีเมธอด parse
ที่รับข้อมูล data
และตรวจสอบ schema
ว่ามี parse หรือไม่ ถ้ามีเราใช้ parse
จาก schema
นี้เพื่อแปลงข้อมูล data
และคืนค่าออกมา ถ้าไม่มีเราใช้ schema
โดยตรงเพื่อแปลงข้อมูล data และคืนค่าออกมา.
;
นอกจากนี้เรายังสร้าง InferEntity
ซึ่งเป็นประเภทที่ใช้สำหรับการดึงประเภทข้อมูลจาก Entity
โดยอัตโนมัติ แต่ถ้าไม่ใช่ Entity
ก็จะคืนค่า never.
ต่อมาเรามาดูตัวอย่างการใช้งาน:
// Consumer
;
;
;
;
// Type will be
// const data: {
// name: string;
// email: string;
// } | undefined
ในตัวอย่างนี้เราสร้าง Entity
ของผู้ใช้ (UserEntity
) โดยใช้ Zod เป็น schema
ที่กำหนดข้อมูลของผู้ใช้ และเราใช้ parse
เพื่อแปลงข้อมูลที่เราส่งเข้ามาใน data
กับ schema
ของเรา ในที่นี้เราจะได้ผลลัพธ์ที่เป็น UserEntity
หรือ never
ถ้าไม่สามารถแปลงข้อมูลได้.
หรือเราสามารถประกาศแค่ Generic ก็ได้โดยไม่ต้องใช้ Zod
;
;
// Type will be
// const data: {
// name: string;
// } | undefined
หวังว่าบทความนี้จะช่วยให้คุณเข้าใจการสร้างฟังก์ชั่นทั่วไปสำหรับเครื่องมือตรวจสอบข้อมูลใน TypeScript ได้เพิ่มเติมครับ!
อ่านเพิ่ม
ลองดูตัวอย่างการรับ Data Validation หลายๆ เจ้าดูนะ โดยไม่ผูกติด
- TypeSchema -- Universal adapter for schema validation
- tRPC's input & output validators
- untypeable