DevGuide – Telegram
11.1K subscribers
2.94K photos
19 videos
135 files
3.62K links
Level up daily with insider dev hacks, smart career tips, and real talk! 🚀

⚡️ Stay connected with me: linktr.ee/AliSamir

📍 To advertise on the channel: https://telega.io/c/the_developer_guide
Download Telegram
Master React: From Start to Finish — Your Ultimate Guide to Becoming a React Rockstar 🚀


React isn’t just a library—it’s a superpower. From startups to tech giants like Facebook and Airbnb, React powers the modern web.

Today, I’m sharing how you can master it, from your first "Hello World" to building full-blown, scalable applications.

———

📍 Why React? The Hype Is Real
🌱 1. The Foundations — Before React
⚛️ 2. The Core of React — Your Bread & Butter
🧠 3. Dive Deeper — Intermediate React
🧰 4. Tooling & Ecosystem — The Secret Sauce
🔁 5. State Management — Do You Really Need Redux?
🧱 6. Component Design & Reusability — Think Like a Pro
📦 7. TypeScript + React — The Modern Duo
🚀 8. Performance Optimization — Smooth & Snappy UIs
🔄 9. Testing — Write Code That Doesn’t Break
🌐 10. Go Full Stack (Optional but Powerful)
💼 11. Portfolio, Jobs & Interviews — The Final Boss

———

https://dev.to/alisamir/master-react-from-start-to-finish-your-ultimate-guide-to-becoming-a-react-rockstar-4a0a
5👍2
VSCodium

Free/Libre Open Source Software Binaries of VS Code

VSCodium is a community-driven, freely-licensed binary distribution of Microsoft’s editor VS Code.

https://vscodium.com
5👍2
يعني إيه CDN؟ 🌍

كلمة CDN هي اختصار لـ Content Delivery Network، يعني "شبكة توصيل المحتوى"، ودي واحدة من الحاجات اللي بتسرّع مواقع الويب بشكل خرافي وبتخلي تجربة المستخدم أحسن بكتير، وخليني أشرحلك إزاي وليه 👇

———

🎯 المشكلة الأساسية:


تخيل إنك عامل موقع ومتخزن على سيرفر موجود في أمريكا، وجالك زائر من مصر... كل ما يفتح الموقع، جهازه بيبعَت طلب (request) للسيرفر اللي في أمريكا، والسيرفر بيرد عليه بالملفات (صور، CSS، JavaScript...)

المشكلة إن المسافة بعيدة، وده بيخلّي وقت تحميل الصفحة أطول 😩

———

💡 الحل؟ هنا ييجي دور الـ CDN


الـ CDN عبارة عن شبكة كبيرة جدًا من السيرفرات (بنسمّيهم Edge Servers) منتشرين في كل مكان في العالم — في مصر، السعودية، أوروبا، أمريكا، آسيا... إلخ.

لما تستخدم CDN، هو بيخزن نسخة من الملفات الثابتة بتاعة موقعك (زي الصور، ملفات CSS و JS، الخطوط، الفيديوهات...) على كل السيرفرات دي.

يعني لما حد من مصر يفتح موقعك، بدل ما يتواصل مع السيرفر الأساسي في أمريكا، هيتواصل مع أقرب سيرفر ليه جغرافيًا (مثلاً في القاهرة أو دبي)، وده بيخلي الموقع يفتح بسرعة🚀

———

📦 بيخزن إيه بالظبط؟


الـ CDN بيخزن أي حاجة Static، يعني ملفات مش بتتغير كتير زي:

- صور (JPEG، PNG، WebP...)
- ملفات CSS و JavaScript
- خطوط - Fonts
- فيديوهات
- وحتّى ملفات HTML لو الموقع Static

———

🔐 طب هل الـ CDN بيأثر على الأمان؟


نعم، بيساعد في الأمان عن طريق:

- بيقدر يمنع الهجمات زي DDoS لأن الطلبات بتتوزع على سيرفرات كتير
- بيخفي الـ IP الحقيقي للسيرفر الأساسي
- بيقلل التحميل على الباك إند بتاعك

———

🧪 طب إيه الفائدة ليا كمبرمج؟


لو شغال على موقع أو Web App:

استخدام CDN هيحسّن سرعة الموقع

يقلل الـ (Bandwidth) المستهلك من السيرفر الرئيسي

بيحسّن ترتيب الموقع في جوجل (SEO)

ويخلّي الزوار مبسوطين ومش هيمشوا من أول ثانية 😅

———

🔥 أمثلة على CDN مشهورة:


- Cloudflare
- Akamai
- Amazon CloudFront
- Fastly
- Google CDN

ولو شغال في React أو Next.js، هتلاقي أدوات زي Vercel و Netlify بيستخدموا CDN بشكل تلقائي في الخلفية.

———

#دقيقة_برمجة
4👍4
الوجه الآخر لـ Tailwind CSS

بفضل الله وتوفيقه، تم نشر ثالث مقال في مدونة Level Up Coding على منصة Medium 🔥

———

The Dark Side of Tailwind: When Utility Classes Become a Mess

Tailwind CSS has taken the web development world by storm, promising rapid prototyping, customizable designs, and a utility-first approach that feels like a breath of fresh air.

Developers love it. Designers tolerate it. And for many, it’s the holy grail of modern front-end frameworks. But let’s be real — there’s a dark side to Tailwind that no one talks about until they’re knee-deep in a tangled mess of unreadable HTML.

So, grab your coffee, and let’s dive into why Tailwind’s utility classes can sometimes turn your clean codebase into a chaotic nightmare.

———

📌 رابط المقال:

https://medium.com/gitconnected/the-dark-side-of-tailwind-when-utility-classes-become-a-mess-f339fb72cb81
5
الـ DoS Attack ⚡️
.
.
تخيّل أنك شغال على مشروعك، والموقع مستقر وكل حاجة تمام… وفجأة تلاقي كل حاجة وقفت، السيرفر مش شغال ولا بيرد على الطلبات اللي رايحه...

تدخل تشوف المشكلة، تلاقي الترافيك عالي جدًا بشكل مش طبيعي، ومفيش أي explanation واضح...

في اللحظة دي، لازم يكون أول حاجة تيجي في بالك: DoS Attack
الهجوم البسيط في فكرته، لكن ممكن يوقّع سيستم كامل في ثواني، مهما كان حجمه أو قوته (في الغالب).

———

📍 LinkedIn

https://www.linkedin.com/posts/dev-alisamir_dos-softwareengineer-devabrguide-activity-7316886145286520832-cCKa

📍 Qabilah

https://qabilah.com/posts/68AhwGkw1Vk
4👍1
الفرق بين Low-level و High-level Languages 🧠

تعال نتكلم عن حاجة أساسية في عالم البرمجة، وهي نوعين من اللغات اللي بنكتب بيهم الكود:

Low-level Languages & High-level Languages

———

🔧 أولًا: الـ Low-level Languages


دي اللغات اللي بتتكلم تقريبًا بلغة الكمبيوتر نفسه، قريبة جدًا من الـ Hardware.
يعني لما تكتب كود بلغة Low-level، أنت بتتعامل مع الحاجات اللي داخل الجهاز نفسه زي الرامات، المعالج، وهكذا.


📌 أمثلة عليها؟

- Assembly Language
- Machine Code


الميزة؟

- سريعة جدًا لأنها بتشتغل على مستوى قريب من الجهاز.
- بتوفر لك تحكم عالي جدًا في الموارد (زي الرامات والمعالج).


العيب؟

- صعبة جدًا في الفهم.
- أي غلطة ممكن تعملك مشاكل كبيرة.
- كتابة البرامج بها بياخد وقت ومجهود كبير.

———

🎩 ثانيًا: الـ High-level Languages


دي بقى اللغات اللي احنا بنتعامل بها في الغالب.
اللغات دي أقرب للبني آدم من الآلة، يعني تقدر تكتب الكود بلغة مفهومة شبه الإنجليزي، وتسيب للمترجم (compiler أو interpreter) مهمة تحويل الكلام ده للغة الكمبيوتر.


📌 أمثلة عليها؟

- Python
- JavaScript
- Java
- Ruby
- Go


الميزة؟

- سهلة في التعلم والقراءة والكتابة.
- أسرع في تطوير البرامج.
- بتوفر أدوات ومكتبات بتسهل عليك الشغل جدًا.


العيب؟

- أبطأ شوية من Low-level لأن في طبقة وسيطة (المترجم أو الـ runtime).
- مش دايمًا بتديك تحكم كامل في الـ Hardware.

———

#دقيقة_برمجة
4
شهادات Mongodb الرقمية

شهادات رقمية سريعة، مجانية تساعدك على تعلم مهارات جديدة في MongoDB وإبرازها من خلال شارة رقمية قابلة للمشاركة.

ابدأ الآن مجانًا:

https://learn.mongodb.com/skills
6👍1🔥1
الفرق بين الـ Compiler والـ Interpreter؟ ⚙️

لما تيجي تكتب كود بلغة برمجة زي C أو Python، الكود ده مش مفهوم بشكل مباشر للجهاز (لأن الجهاز بيفهم 0 و 1 بس)، فمحتاج حد يترجم له من لغة البشر إلى لغة الآلة.

وهنا بييجي دور الـ Compiler و الـ Interpreter، وظيفتهم الأساسية هي "ترجمة الكود"، لكن كل واحد له طريقته المختلفة.

———

📌 أولًا: الـ Compiler


الـ Compiler هو مترجم بياخد الكود كله مرة واحدة، يراجعه، يحوله للغة الآلة (machine code)، وبعد كده يشغل البرنامج.

مثال: زي ما تكون بتكتب مقال، وتديه للمصحح اللغوي يراجعه بالكامل، وبعد كده تنشره مرة واحدة.

📍 لغات مشهورة بتستخدم الـ Compiler:


- C
- C++
- Go
- Rust


مميزاته:

- بيطلع برنامج سريع جدًا وقت التشغيل (لأن الترجمة حصلت قبل ما يبدأ يشتغل).
- ممكن يكتشف أخطاء كتير قبل ما تشغل البرنامج.


عيوبه:

- أي تعديل في الكود، لازم تعيد الترجمة من الأول.
- وقت الترجمة ممكن يكون طويل شوية.

———

📌 ثانيًا: الـ Interpreter


الـ Interpreter بيشتغل بطريقة مختلفة، هو بيترجم الكود سطر بسطر، يعني كل ما يلاقي سطر بيترجمه ويشغله فورًا.

مثال: زي مدرس بيقرأ جملة من كتاب بلغة أجنبية، ويترجمها لك في نفس اللحظة.

📍 لغات مشهورة بتستخدم الـ Interpreter:

- Python
- Ruby
- PHP

مميزاته:

- سهل تجرب الكود بسرعة وتشوف النتيجة فورًا.
- ممتاز في التعليم أو التطوير السريع (prototyping).


عيوبه:

- أبطأ في الأداء وقت التشغيل (لأنه بيترجم أثناء التشغيل).
- ممكن ما يتعرف على أخطاء موجودة في الكود غير لما يوصل للسطر اللي فيه المشكلة.

———

#دقيقة_برمجة
5👍4
الفرق بين MVC و MVVM و MVP 🧩
.
.
لو بتسمع عن المصطلحات الغريبة دي (MVC، MVP، MVVM) ومش فاهم معناها إيه، تعال نبسط الموضوع...

تخيل إنك بتبني أبلكيشن بيعرض بيانات للمستخدم، وبتعدل البيانات دي من وقت للتاني... طبيعي الكود هيتقسم لأجزاء عشان تفضل الدنيا منظمة، مش كود واحد كبير متشابك.

هنا بييجي دور الـ Design Patterns اللي بتنظم طريقة كتابة الكود، وأشهرهم:

———

🔹 الـ MVC - Model View Controller


- الـ Model: ده الجزء اللي بيحفظ ويتعامل مع البيانات (زي الـ database).
- الـ View: الجزء اللي المستخدم بيشوفه (الـ UI).
- الـ Controller: هو اللي بيتلقى الأوامر من المستخدم (زي لما يضغط على زرار)، ويكلم الـ Model، وبعد كده يخلّي الـ View تعرض البيانات.

🎯 مثال: المستخدم بيكتب اسمه، الـ Controller ياخده، يحفظه في الـ Model، وبعد كده يرجّع الاسم للـ View عشان تعرضه.

———

🔹 الـ MVP - Model View Presenter


- الـ Model: نفس الفكرة بتاعت البيانات.
- الـ View: الجزء اللي المستخدم بيشوفه (الـ UI).
- الـ Presenter: هو "دماغ" التطبيق، بيتعامل مع الـ Model، ويبعَت النتائج للـ View تعرضها. والجميل هنا إن الـ View مبتعرفش حاجة عن الـ Model.

🎯 مثال: المستخدم ضغط زرار، الـ View تبعت الإشارة للـ Presenter، هو اللي يتصرف ويرجع النتيجة.

فائدة الـ MVP: سهل تختبره (Testing) لأن الـ Presenter مفصول عن الـ UI.

———

🔹 الـ MVVM - Model View ViewModel


ده pattern معمول مخصوص للـ UI اللي بتشتغل بـ Data Binding (زي Angular، React، أو حتى Flutter):

- الـ Model: البيانات كالعادة.
- الـ View: الـ UI.
- الـ ViewModel: هو اللي بيربط الاتنين ببعض. بيحول البيانات بشكل يناسب العرض، وبيتعامل مع الـ logic. هنا الـ View والـ ViewModel بيرتبطوا ببعض تلقائيًا عن طريق الـ Data Binding.

🎯 لما المستخدم يكتب حاجة، الـ ViewModel يلاحظ التغيير ويحدث الـ Model، والـ View تتحدث بشكل تلقائي.

———

📌 طب أختار إيه؟


لو شغال على مشروع تقليدي أو backend بسيط: جرب MVC.

لو عايز UI سهل في الاختبار والـ View مفصولة: MVP هو اختيارك.

لو بتشتغل بحاجة فيها Data Binding (زي Angular أو Flutter أو React): MVVM هو الأفضل.

———

#دقيقة_برمجة
8
Recursion Explained with Pizza (You’ll Never Forget It Again)


https://dev.to/alisamir/recursion-explained-with-pizza-youll-never-forget-it-again-3m8a
5
الفرق بين Static Typing و Dynamic Typing ⌨️
.
.
قبل ما تدخل في مقارنة بين لغات البرمجة، لازم تبقى فاهم الفرق بين نوعين مهمين جدًا من أنواع اللغات:

الـ Static Typing و Dynamic Typing، وده بيتعلق بإزاي اللغة بتتعامل مع أنواع البيانات (Data Types) زي أرقام، نصوص، Boolean... إلخ.

———

📌 الـ Static Typing


اللغات اللي بتستخدم النظام ده بتتأكد من نوع البيانات وقت الكتابة (وقت الـ Compile)، مش وقت التشغيل.

يعني وأنت بتكتب الكود، لازم توضح نوع كل متغيّر (variable)، والمترجم (Compiler) هيبقى بيراجع الأنواع دي ويتأكد إنها ماشية صح.

مثال بلغة TypeScript:

let age: number = 25;
age = "Hello"; // Error قبل ما الكود يتنفذ


لو حاولت تدي قيمة مختلفة للنوع المتوقع، هيظهر لك خطأ على طول قبل ما الكود يشتغل.


📍 مميزات الـ Static Typing:


- بيقلل الأخطاء في وقت التشغيل.
- بيساعد أدوات التطوير (IDE) إنها تكملك الكود وتديك تحذيرات.
- بيخلي الكود أوضح وأسهل في الصيانة.

———

📌 الـ Dynamic Typing


هنا بقى، اللغة مش هتسألك عن نوع المتغيّر، هتسيبك تكتب براحتك، وتحدد نوعه على حسب القيمة اللي هتحطها فيه وقت التشغيل.

مثال بلغة JavaScript:

let age = 25;
age = "Hello"; // عادي جدًا


يعني نفس المتغيّر ممكن يكون رقم في سطر، و string في السطر اللي بعده، واللغة مش هتعترض


📍 مميزات الـ Dynamic Typing:

- الكود بيبقى أسرع في الكتابة.
- مناسب للتجريب والتطوير السريع (Rapid Prototyping).
- مرن أكتر في بعض الحالات.


———

🎯 أمثلة للغات Static Typing:


TypeScript, Java, C++, Kotlin

🔥 أمثلة للغات Dynamic Typing:


JavaScript, Python, Ruby, PHP

———

#دقيقة_برمجة
4👏2
🔥6👏1
1- The 10 Front-End Mistakes I Wish I Knew as a Beginner (With Fixes) 💡
https://levelup.gitconnected.com/the-10-front-end-mistakes-i-wish-i-knew-as-a-beginner-with-fixes-cec0f6430455

2- How to Build a Scalable Back-End with Zero Downtime Deployments 🚀
https://levelup.gitconnected.com/how-to-build-a-scalable-back-end-with-zero-downtime-deployments-6f10b6d1f389

3- The Dark Side of Tailwind: When Utility Classes Become a Mess ⚠️
https://levelup.gitconnected.com/the-dark-side-of-tailwind-when-utility-classes-become-a-mess-f339fb72cb81
👍5👏1
يعني إيه API Gateway؟
.
.
تخيل معايا إنك داخل مطعم كبير جدًا، والمطبخ فيه أكتر من شيف:
واحد مسؤول عن البيتزا 🍕، والتاني عن الحلويات 🍰، والتالت عن المشروبات ☕️.

وأنت كـ زبون، مش هتروح لكل شيف وتطلب منه، صح؟
فيه جرسون (الـ waiter) بياخد طلبك ويوصّله للمطبخ، ويجيبلك الأكل كله مرّة واحدة.

الجرسون ده في عالم البرمجة اسمه: API Gateway.


———

💡 يعني إيه API Gateway؟


ببساطة، الـ API Gateway هو حارس البوابة أو نقطة الدخول الوحيدة لكل الـ APIs اللي السيرفر أو النظام بيقدّمها.

لو عندك نظام ضخم (زي موقع تجارة إلكترونية مثلًا)، هتلاقي كل جزء فيه شغّال كـ Microservice:

- جزء لطلب الأوردرات
- جزء لحسابات المستخدمين
- جزء للمنتجات
- جزء للدفع الإلكتروني


الـ API Gateway بيجمع كل الخدمات دي وبيخلي الـ Frontend أو الموبايل يتعامل مع نقطة واحدة بس، بدل ما يبعت طلبات متفرقة لكل خدمة.

———

🤔 ليه نستخدم API Gateway؟


توحيد نقطة الاتصال
بدل ما الـ Frontend يتعامل مع 5 أو 10 APIs، بيتعامل مع gateway واحدة.

🔐 الأمان
الـ Gateway تقدر تضيف layer للأمان: JWT, API keys, Rate limiting... إلخ.

📊 المراقبة والتحليل
تقدر تعرف مين بيطلب إيه، وإمتى، وتراقب كل حاجة من مكان واحد.

📦 الـ Caching و Load Balancing
ممكن يخزّن الردود (Cache) ويوزّع الأحمال بشكل ذكي.

🔁 تحويل البيانات
لو خدمة بترد بـ XML وانت محتاج JSON، الـ Gateway ممكن يتصرف.

———

🛠 أمثلة حقيقية لـ API Gateways:


- Kong
- AWS API Gateway
- Nginx
- Apigee
- Zuul

———

#دقيقة_برمجة
👍81👏1
Advanced React: Building Scalable Apps with Design Systems, Patterns, and Performance 🚀


In this article, we’ll dive into advanced React techniques, focusing on design systems, design patterns, and performance optimization to help you build robust, user-friendly applications that scale effortlessly.

https://dev.to/alisamir/advanced-react-building-scalable-apps-with-design-systems-patterns-and-performance-229
3
دورات مجانية عن بُعد بشهادة إتمام؛ متاحة لك في أي وقت ومن أي مكان

https://satr.codes
6🔥1