โหมดติวตอบกรรมการ

แสดงทีละหัวข้อจาก /docs/CODE_STUDY_GUIDE.md

ความคืบหน้า 54 / 62 (87%)
หัวข้อที่ 54 จากทั้งหมด 62

Q9: "Error Handling ทำอย่างไร?"

สรุปสั้น: แนวตอบ ใช้ 3 ชั้น 1. asyncHandler() — ครอบ async function → auto catch 2. errorConverter — แปลง Error ทั่วไปเป็น ApiError 3. errorHandler — ส่ง JSON response, log error, ซ่อน stack trace ใน production Frontend api.service.ts จัดกา...

คำสำคัญ

  • error
  • auto
  • apierror
  • errorhandler
  • backend
  • src

คำถามที่กรรมการมักถาม

  1. หัวข้อ "Q9: "Error Handling ทำอย่างไร?"" คืออะไร และทำไมถึงสำคัญกับโปรเจกต์ของคุณ?
  2. ตอนออกแบบเรื่อง auto คุณเทียบทางเลือกอะไรบ้าง และเหตุผลที่เลือกวิธีสุดท้ายคืออะไร?
  3. ถ้ากรรมการท้วงเรื่อง apierror คุณจะอธิบายและป้องกันแนวทางนี้อย่างไร?
  4. ถ้าต้องปรับปรุง error ให้ดีขึ้นทันที คุณจะเริ่มแก้อะไรก่อน เพราะอะไร?

ตัวอย่างคำตอบ

สำหรับหัวข้อ "Q9: "Error Handling ทำอย่างไร?"" เป้าหมายหลักคือ แนวตอบ ใช้ 3 ชั้น 1. asyncHandler() — ครอบ async function → auto catch 2. errorConverter — แปลง Error ทั่วไปเป็น ApiError 3. errorHandler — ส่ง JSON response, log error, ซ่อน stack trace ใน production Frontend api.service.ts จัดกา... แนวทางที่ใช้เชื่อมโยงกับความต้องการระบบ ช่วยให้ระบบเชื่อถือได้และดูแลง่ายขึ้น และเมื่อเทียบกับทางเลือกอื่นถือว่าเหมาะสมที่สุดภายใต้ข้อจำกัดของโปรเจกต์นี้

คำนวณยังไง

  • เปอร์เซ็นความคืบหน้า: Math.round((index / total) * 100) = Math.round((54 / 62) * 100) = 87%
  • ลำดับหัวข้อปัจจุบัน: รับจาก query ?section= แล้วบังคับให้อยู่ในช่วง 1..62 ค่าที่รับมา: 54, ค่าสุดท้าย: 54
  • จำนวนหัวข้อทั้งหมด: 62 (นับจากหัวข้อ markdown ระดับ ## และ ###)
  • สรุปสั้น: สร้างจาก summarizeText(stripMarkdown(sectionContent), 230)
  • คำสำคัญ: ดึงจากความถี่คำในชื่อหัวข้อ + เนื้อหา หลังกรองคำฟุ่มเฟือย (stopwords)
  • คำถามกรรมการ: สร้างจาก template โดยอิงชื่อหัวข้อและคำสำคัญหลัก