data:image/s3,"s3://crabby-images/10653/10653f0fd4354b7962c16f4a80cef2cdcd71efdc" alt="x32x01"
x32x01
أدارة أكتب كود
- بواسطة x32x01 ||
data:image/s3,"s3://crabby-images/5bb7d/5bb7d0792b14c5b56e97a56d03a27c372ddff6be" alt="Fire :fire: 🔥"
data:image/s3,"s3://crabby-images/5bb7d/5bb7d0792b14c5b56e97a56d03a27c372ddff6be" alt="Fire :fire: 🔥"
النسخة الجديدة جاية بميزات جامدة جدًا هتسهل علينا حاجات روتينية كنا بنعملها ، أهمها:
data:image/s3,"s3://crabby-images/6ff10/6ff103ec53027ad68cffb812ae71547497add1e9" alt="Star :star: ⭐"
الميزة دي بتخلّي التعامل مع الـ Forms أسهل بكتير، وخصوصًا في تعديل البيانات. باستخدام useActionState، هتقدر تدير الستيت بتاعت الفورم بسلاسة.
data:image/s3,"s3://crabby-images/372c5/372c5cbb4cdaf68b3f8c150f7a65c854aa59e4d8" alt="Blue circle :blue_circle: 🔵"
JavaScript:
function UpdateProfile() {
const [error, submitAction, isPending] = useActionState(
async (previousState, formData) => {
const name = formData.get("name");
try {
await updateProfile(name);
return null; // مفيش أخطاء
} catch (err) {
return "فشل في تحديث الملف الشخصي";
}
},
null
);
return (
<form action={submitAction}>
<input type="text" name="name" />
<button type="submit" disabled={isPending}>
{isPending ? "جاري التحديث…" : "تحديث الملف"}
</button>
{error && <p className="error">{error}</p>}
</form>
);
}
data:image/s3,"s3://crabby-images/55d04/55d04a4ede2ab4005da4e99e26579bc76f5543ed" alt="Green circle :green_circle: 🟢"
دلوقتي ممكن تعرض حالة التحميل بسهولة باستخدام useFormStatus:
JavaScript:
import { useFormStatus } from 'react-dom';
function SubmitButton() {
const { pending } = useFormStatus();
return (
<button disabled={pending}>
{pending ? 'جاري الإرسال…' : 'إرسال'}
</button>
);
}
data:image/s3,"s3://crabby-images/de8a2/de8a2f6146fb53d4d3965c0fc5744205a3378722" alt="Rocket :rocket: 🚀"
لو استفدت، اديني ريأكت، وشير عشن تفيد غيرك
data:image/s3,"s3://crabby-images/7028b/7028bf4051b2b3e90ed98d0fd669116c63632508" alt="Blue heart :blue_heart: 💙"
وقولى إيه أكتر ميزة عجبتك في الاصدار الجديد؟