React يجعل إنشاء واجهات المستخدم التفاعلية سهلا للغاية، ﻻ يجب عليك سوى أن تصمم واجهة بسيطة لكل حالة من حالات التطبيق و بعدها React يتكفل وبفاعلية بتحديث و إعادة رسم المكّون المعني بالتحديث فقط عند تغيُّر البيانات.
الواجهات المُعرّفة (التصريحية)، تجعل الشيفرة الخاصة بالبرنامج سهلة التوقع عند تنفيذها و سهلة التصحيح في حالة وجود أخطاء.
يعتمد React بشكل أساسي على مفهوم المكوّنات (Components). حيث يجب عليك بناء مكوّنات مُغلَّفة تُدير حالتها الخاصّة، ومن ثمّ تُركِّب هذه المكوّنات مع بعضها لإنشاء واجهات مستخدم مُعقّدة.
بما أنّ منطق المكوّنات مكتوب باستخدام JavaScript بدلًا من صيغة القوالب، فبإمكانك تمرير الكثير من البيانات عبر تطبيقك بسهولة وإبقاء الحالة بعيدة عن DOM.
نحن لا نضع أي فرضيات مسبقة عن التكنولوجيا الأخرى التي تستخدمها، فلهذا يمكنك تطوير ميزات و إضافات باستخدام React دون الحاجة الى إعادة كتابة أي شيفرة مكتوبة سابقاً.
يُمكِن تصيير React من جهة الخادم باستخدام Node.js، ويمكن إنشاء تطبيقات الهواتف الذكية عبر React Native.
كل مكوّن React مزوّد بالدّالة Render()
التي تأخذ البيانات المدخلة و تُرجع ما يجب اظهاره.
هذا المثال يستخدم تعابير تشبه XML أي (XML-Like) و التي تسمى JSX.
البيانات المرسلة خلال المكّون يمكن الوصول اليها ضمن الدالة Render()
بواسطة this.props
.
استخدام JSX اختياري، وليس مطلوباً او شرطاً لاستخدام React. جرّب Babel REPL لترى شيفرة الـ JavaScript الخام الموّلدة من خلال خطوة التحويل البرمجي لـ JSX.
بالإضافة الى أخذ بيانات الإدخال (التي يمكن الوصول إليها من خلال this.props
)، يستطيع المكوّن أن يحتفظ بحالة بياناته الداخلية (التي يمكن الوصول إليها من خلال this.state
) . عندما تتغير حالة بيانات المكوّن، العلامات المرسومة أو المُظهرة سيتم تحديثها و إعادة رسمها من خلال إعادة تنفيذ الدّالة render()
.
باستخدام props
و state
، نستطيع ان ننشأ برنامج صغير يعرض قائمة المهام التي يجب القيام بها (Todo list). هذا المثال يستخدم state
لمتابعة العناصر الموجودة في القائمة الحالية بالإضافة الى متابعة النص المُدخل من قبل المستخدم.
على الرغم من أن معالجات الأحداث تبدو وكأنها مُضمّنة، إلا أنه سيتم جمعها وتنفيذها باستخدام تفويض الحدث.
يسمح React باستخدام مكتبات (Libraries) خارجية بالإضافة الى أُطر عمل (Frameworks).
هذا المثال يستخدم المكتبة remarkable كمكتبة خارجية لمعالجة تعابير من نوع Markdown، لتحويل قيمة <textarea>
بشكل آني.