إزاي تستخدم Web Components ببساطة وذكاء

يوليو 6, 2025

إزاي تستخدم Web Components ببساطة وذكاء

كتير من المطورين بيفكروا إن Web Components معمولة عشان تبقى بديل كامل لفريموركات زي React أو Vue. بس الحقيقة إنك ممكن تستخدمها بطريقة أسهل بكتير، وتركز على تعزيز (Enhance) صفحات HTML عادية بتطلع من السيرفر من غير أي تعقيد.


المشكلة: بنعقد نفسنا زيادة عن اللزوم

بعض المطورين بيبدأوا يستخدموا Web Components وبيفترضوا إنهم محتاجين يعملوا Shadow DOM، ويضيفوا أدوات Routing، وإدارة State، كأنهم بيبنوا SPA كاملة.

بس ده مش الهدف الأساسي من Web Components. هي أداة بسيطة تقدر تستخدمها عشان تضيف تفاعلات صغيرة على الـ HTML اللي السيرفر جايبه لك.


الحل: استخدم Web Components للتحسين التدريجي

يعني ببساطة، إنت بتعرض صفحة HTML عادية فيها عناصر متاحة لكل المستخدمين، وبعدين تضيف فوقها شوية سلوك تفاعلي من خلال JavaScript.

مثال عملي: كارت تسعير

تخيل عندك الكود ده:

<pricing-card>
  <price-option class="monthly hidden">99 جنيه / شهر</price-option>
  <price-option class="yearly">999 جنيه / سنة</price-option>
</pricing-card>
  

المستخدم يشوف السعر السنوي بشكل افتراضي. لما يغير نوع الاشتراك (مثلاً من خلال زرار)، Web Component هيبدّل بين السعرين:

class PricingCard extends HTMLElement {
  connectedCallback() {
    this.addEventListener('change', () => {
      this.querySelector('.monthly').classList.toggle('hidden');
      this.querySelector('.yearly').classList.toggle('hidden');
    });
  }
}
customElements.define('pricing-card', PricingCard);
  

ليه الطريقة دي قوية؟

  • HTML شغال كويس من غير جافاسكريبت
  • الكومبوننت بيتفاعل مع الصفحة من غير أي إطار عمل
  • أداء عالي وسريع في التحميل
  • كودك بيشتغل على كل المتصفحات الحديثة بدون تعديلات

مثال تاني: إضافة عناصر لقائمة

عايز تخلي المستخدم يضيف عناصر جديدة في القائمة؟ تقدر تستخدم template:

<dynamic-list>
  <ul></ul>
  <button>أضف عنصر</button>
  <template>
    <li>عنصر جديد</li>
  </template>
</dynamic-list>
  

وجافاسكريبت بسيط زي ده:

class DynamicList extends HTMLElement {
  connectedCallback() {
    this.template = this.querySelector('template');
    this.list = this.querySelector('ul');
    this.querySelector('button').addEventListener('click', () => {
      const item = this.template.content.cloneNode(true);
      this.list.appendChild(item);
    });
  }
}
customElements.define('dynamic-list', DynamicList);
  

طرق تمرير البيانات داخل الكومبوننت

  • عن طريق خصائص زي data-user-id، وتقرأها بـ this.dataset.userId
  • عن طريق الأحداث (Custom Events)
  • عن طريق دوال عامة في الكلاس تتنادي من بره

أمثلة من الواقع

  • استخدام Web Component لعرض Chart.js بتتحدث تلقائي لما البيانات تتغير
  • دمج بوابة دفع Stripe جوا عنصر مخصص بيتحمل بعد ما السكريبت الرئيسي يوصل
  • مشاركة الحالة بين أكتر من عنصر باستخدام Nanostores مع Web Components

الخلاصة

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

المدونة

أحدث مميزات ECMAScript 2025

يونيو 30, 2025

أحدث مميزات ECMAScript 2025 في 25 يونيو 2025، تم اعتماد ES2025 رسميًا. الإضافات الجاية هتسهل عليك كتابة الكود: 1. 📦 Import Attributes و JSON Module...

تعزيز PHP Enums باستخدام archtechx/enums

يوليو 01, 2025

تعزيز PHP enums باستخدام حزمة archtechx/enums من PHP&nbsp;8.1، ظهر نوع جديد اسمه &ldquo;enums&rdquo; بيخليك تعرف قيم ثابتة بأسماء مرمّزة زي statuses...

React Labs: View Transitions وActivity

يونيو 17, 2025

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

إتقان التحقق الشرطي في Laravel 12

يوليو 07, 2025

إتقان التحقق الشرطي في Laravel&nbsp;12 في Laravel&nbsp;12، نظام التحقق (validation) قوي جدًا، وميزة التحقق الشرطي بتخليك تتحكم في القوانين بتاعتك ب...

الفرق بين Redux, Context & React Components في إدارة الحالة

أغسطس 06, 2025

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

نظرة معمقة على Laravel Context: تسجيل وتحليل السياق البرمجي باحترافية

يوليو 20, 2025

في Laravel 12، تم تقديم Laravel Context كأداة قوية بتخلي تتبع الطلبات، تسجيل الأخطاء، وتحليل سلوك الوظائف الخلفية أسهل وأدق من أي وقت فات. وده بيحصل ع...