我嘗試遵循 svelte 中的 zod 驗證教程。我對此沒有經驗(svelte),所以我想知道如何在簡單的 React/next 應用程式中複製此程式碼功能?我陷入困境({request})將是什麼/我將傳遞給非同步函數。
此外,這應該在 useEffect 內部進行還是僅在表單提交時調用?
export const actions = { default: async ({ request }) => { const formData = Object.fromEntries(await request.formData()); console.log('Form Data:', formData); try { const result = registerSchema.parse(formData); console.log('SUCCESS'); console.log(result); } catch (err) { const { fieldErrors: errors } = err.flatten(); const { password, passwordConfirm, ...rest } = formData; return { data: rest, errors }; } };
這裡是本教學的儲存庫:https://github.com/huntabyte/sveltekit-form-validation/blob/main/src/routes/+page.server.js
P粉7147807682024-01-29 16:12:27
這就是我所做的:
總的來說,我發現這種方法效果很好,並且易於理解和實施。至於您關於在哪裡放置驗證程式碼的問題,我建議在表單提交時呼叫它,而不是在 useEffect 中呼叫它。