پرسش

چطور داده‌های یک فرم رو توی React بگیرم؟

من دارم با React کار می‌کنم و می‌خوام وقتی یه فرم رو سابمیت می‌کنم، داده‌های اون فرم رو دریافت کنم. می‌خواستم بدونم چطور می‌تونم این کار رو انجام بدم و بهترین روش برای این کار چیه؟ آیا باید از state استفاده کنم یا راه بهتری هم هست؟

1403/06/05
پاسخ
محمدامین سعیدی راد
بیوگرافی محمدامین سعیدی راد

برای گرفتن داده‌های فرم در React، چندین روش وجود داره که بسته به نیازت می‌تونی ازشون استفاده کنی. یکی از معمول‌ترین روش‌ها استفاده از state هست. با استفاده از state می‌تونی ورودی‌های فرم رو مدیریت کنی و هر بار که کاربر داده‌ای رو وارد می‌کنه، اون رو توی state ذخیره کنی. بیایید با هم یه مثال ساده ببینیم:

import React, { useState } from 'react';
function MyForm() {
const [formData, setFormData] = useState({
     name: '',
     email: ''
    });
   const handleChange = (event) => {
       const { name, value } = event.target;
       setFormData({
       ...formData,
       [name]: value
   });
};
   // Handle form submission
   const handleSubmit = (event) => {
        event.preventDefault();
        console.log('Form data submitted:', formData);
   };
    return (
       <form onSubmit={handleSubmit}>
          <div>
             <label>Name:</label>
             <input
             type="text"
             name="name"
             value={formData.name}
             onChange={handleChange}
              />
          </div>
           <div>
              <label>Email:</label>
              <input
              type="email"
              name="email"
              value={formData.email}
              onChange={handleChange}
              />
          </div>
          <button type="submit">Submit</button>
       </form>
);
}
export default MyForm;

در این مثال، ما دو تا ورودی داریم: name و email. وقتی که کاربر متنی رو توی یکی از این فیلدها وارد می‌کنه، تابع handleChange اجرا می‌شه و state رو به‌روز می‌کنه. در نهایت، وقتی فرم سابمیت می‌شه، تابع handleSubmit اجرا می‌شه و می‌تونی داده‌های فرم رو از state بگیری و پردازش کنی.

این روش بسیار متداول و کارآمد هست، ولی اگه فرم خیلی بزرگ و پیچیده‌ای داری، شاید بخوای از کتابخانه‌هایی مثل Formik یا React Hook Form استفاده کنی که مدیریت فرم‌ها رو راحت‌تر می‌کنن.

برای اینکه فرم‌ها رو تمیز و بهینه مدیریت کنی، به این نکات دقت کن:

  • از کنترل‌های فرم به صورت کنترل‌شده استفاده کن تا همیشه داده‌ها توی state به‌روز باشن.
  • اگه فرم پیچیده‌تر شد، حتماً از ابزارهای مدیریت فرم استفاده کن تا کدت بهینه و خوانا بمونه.

این پاسخ می‌تونه یه شروع خوب برای مدیریت فرم‌ها توی React باشه.

پاسخ: 1403/06/05
آخرین آپدیت: 1403/08/10