مكونات واجهة المستخدم والتفاعل الأساسية في React Native

يوليو 1, 2025

مكونات واجهة المستخدم والتفاعل الأساسية في React Native

React Native بتوفرلك مجموعة قوية من المكونات الجاهزة اللي تقدر تستخدمها لبناء تطبيقات موبايل أصلية بدون أي مكتبات خارجية. المقالة دي فيها شرح تفصيلي لكل مكون، مع مثال عملي وسبب استخدامه.

📦 مكونات الواجهة الأساسية

1. View

عنصر أساسي بيستخدم كحاوية لعناصر تانية، زي div في HTML. بنستخدمه لتنظيم العناصر جوه التطبيق.

<View style={{ padding: 20 }}>
  <Text>أهلاً بالعالم!</Text>
</View>

2. Text

للعرض النصوص على الشاشة، وتقدر تتحكم في لونه وحجمه ومحاذاته.

<Text style={{ fontSize: 18, color: 'blue' }}>نص تجريبي</Text>

3. Image

لعرض الصور سواء من الإنترنت أو من ملفات محلية.

<Image source={{ uri: 'https://example.com/image.jpg' }} style={{ width: 100, height: 100 }} />

4. ScrollView

عنصر بيسمحلك تعمل Scroll لو المحتوى أطول من الشاشة.

<ScrollView>
  <Text>محتوى طويل...</Text>
</ScrollView>

5. FlatList

أفضل طريقة لعرض القوائم، خصوصًا لو الداتا كتير.

<FlatList
  data={[{ key: 'عنصر 1' }, { key: 'عنصر 2' }]}
  renderItem={({ item }) => <Text>{item.key}</Text>}
/>

6. TextInput

حقل لإدخال النصوص من المستخدم زي الاسم أو الباسورد.

<TextInput placeholder="اكتب اسمك" style={{ borderWidth: 1, padding: 10 }} />

7. Button

زر بسيط بيقوم بعمل معين عند الضغط عليه.

<Button title="اضغط هنا" onPress={() => alert('تم الضغط!')} />

8. Pressable

عنصر حديث للتفاعل مع الضغط، وبيتيح تحكم أكتر من الزر العادي.

<Pressable onPress={() => console.log('تم الضغط')}>
  <Text>اضغط هنا</Text>
</Pressable>

9. Modal

بيفتح نافذة منبثقة فوق التطبيق، زي التنبيهات أو الفورمات.

<Modal visible={true} transparent={true}>
  <View style={{ marginTop: 100 }}>
    <Text>دي نافذة منبثقة</Text>
  </View>
</Modal>

🎯 مكونات التفاعل

1. Alert

بيظهر رسالة تنبيه من النظام زي "هل أنت متأكد؟".

Alert.alert("تنبيه", "هل أنت متأكد؟")

2. BackHandler

بيتحكم في زر الرجوع في أجهزة أندرويد.

BackHandler.addEventListener('hardwareBackPress', () => {
  // من هنا تتحكم في الرجوع
  return true;
});

3. KeyboardAvoidingView

بيرفع العناصر لما الكيبورد يظهر عشان ميغطيش الفورم.

<KeyboardAvoidingView behavior="padding">...</KeyboardAvoidingView>

📱 مكونات الأنيميشن

1. Animated

API قوي لعمل أنيميشن احترافي للعناصر.

const fadeAnim = useRef(new Animated.Value(0)).current;

Animated.timing(fadeAnim, {
  toValue: 1,
  duration: 1000,
  useNativeDriver: true
}).start();

2. LayoutAnimation

بيعمل أنيميشن تلقائي للتغيرات في تصميم الصفحة.

LayoutAnimation.configureNext(LayoutAnimation.Presets.spring);

المدونة

Redux Toolkit 2.9.0 - شرح التحديثات وتحسينات RTK Query بالتفصيل

فبراير 05, 2026

شرح تحديث Redux Toolkit 2.9.0 إصدار Redux Toolkit 2.9.0 ركّز بشكل أساسي على تحسين أداء RTK Query، وتنظيم طريقة التعامل مع الطلبات غير المتزامنة (...

هل لارافيل بطيء؟ تحسين أداء الاستعلامات والفهارس بأمثلة

يوليو 20, 2025

دليل عملي ومفصل مع أمثلة واقعية وعينات كود تسهّل عليك تفادي بطء Laravel وتحافظ على سرعة التطبيق. 1. 🧠 استدعي اللي محتاجه بس لو بتعمل DB::tabl...

دورة حياة الطلب في Laravel (Request Lifecycle)

مايو 23, 2026

رحلة الـ Request داخل Laravel: الفكرة الأساسية ودورة الحياة الكاملة فهم عميق لكيفية معالجة إطار العمل لارافل للطلبات من البداية وحتى النهاية لإ...

حقق أداءً أعلى لتقارير البيانات الضخمة باستخدام نظام (Queues)

يوليو 07, 2025

إزاي نعمل كاش لتقارير بفترة زمنية ثابتة إزاي نولّد تقارير ضخمة في الخلفية باستخدام الـ Job Queues 1. 🧠 كاش للتقارير بفترة زمنية ثابتة لو ع...

React Labs: View Transitions وActivity

يونيو 17, 2025

React Labs: View Transitions وActivity المنشور اتكتب يوم 23 أبريل 2025 من Ricky&nbsp;Hanlon. في React Labs النهارده بيقدّموا ميزتين تجريبيّتين مودرن...

البرمجة الكائنية (OOP) – المفاهيم الأساسية

أغسطس 09, 2025

البرمجة الكائنية التوجه (Object Oriented Programming - OOP) هي أسلوب حديث في تطوير البرمجيات يُقسّم التطبيق إلى وحدات تسمى كائنات (Objects) تتفاعل م...