العربية

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

مكونات الويب: صياغة عناصر قابلة لإعادة الاستخدام للويب الحديث

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

ما هي مكونات الويب؟

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

فكر فيها على أنها قطع ليغو للويب. كل قطعة (مكون ويب) تمثل جزءًا معينًا من الوظائف، ويمكنك دمج هذه القطع لبناء واجهات مستخدم معقدة. يكمن جمال مكونات الويب في قابليتها لإعادة الاستخدام وعزلها؛ يمكن استخدامها في أي مشروع ويب، بغض النظر عن إطار العمل المستخدم (أو حتى بدون إطار عمل على الإطلاق)، ولن يتداخل تصميمها وسلوكها الداخلي مع بقية تطبيقك.

التقنيات الأساسية لمكونات الويب

تعتمد مكونات الويب على أربع تقنيات أساسية:

فوائد استخدام مكونات الويب

يوفر اعتماد مكونات الويب في سير عمل التطوير الخاص بك العديد من الفوائد:

مثال بسيط: إنشاء عنصر عداد مخصص

دعنا نوضح إنشاء مكون ويب أساسي: عنصر عداد مخصص.

١. تعريف فئة العنصر المخصص

أولاً، نعرّف فئة جافاسكريبت ترث من الفئة HTMLElement.

class MyCounter extends HTMLElement {
 constructor() {
 super();
 // إرفاق shadow DOM بالعنصر.
 this.attachShadow({ mode: 'open' });

 // تهيئة قيمة العداد.
 this._count = 0;

 // إنشاء عنصر زر.
 this.button = document.createElement('button');
 this.button.textContent = 'Increment';
 this.shadowRoot.appendChild(this.button);

 // إنشاء عنصر span لعرض العد.
 this.span = document.createElement('span');
 this.span.textContent = `Count: ${this._count}`;
 this.shadowRoot.appendChild(this.span);

 // ربط دالة الزيادة بحدث النقر على الزر.
 this.button.addEventListener('click', this.increment.bind(this));
 }

 increment() {
 this._count++;
 this.span.textContent = `Count: ${this._count}`;
 }

 connectedCallback() {
 console.log('تم توصيل العنصر المخصص بـ DOM.');
 }

 disconnectedCallback() {
 console.log('تم فصل العنصر المخصص عن DOM.');
 }

 adoptedCallback() {
 console.log('تم نقل العنصر المخصص إلى مستند جديد.');
 }

 attributeChangedCallback(name, oldValue, newValue) {
 console.log(`تغيرت السمة ${name} من ${oldValue} إلى ${newValue}.`);
 }

 static get observedAttributes() {
 return ['count'];
 }
}

٢. تعريف Shadow DOM

السطر attachShadow({ mode: 'open' }) يرفق shadow DOM بالعنصر. الخيار mode: 'open' يسمح لجافاسكريبت من الخارج بالوصول إلى shadow DOM، بينما mode: 'closed' يمنع الوصول الخارجي.

٣. تسجيل العنصر المخصص

بعد ذلك، نقوم بتسجيل العنصر المخصص في المتصفح باستخدام الدالة customElements.define().

customElements.define('my-counter', MyCounter);

٤. استخدام العنصر المخصص في HTML

الآن يمكنك استخدام العنصر <my-counter> في ملف HTML الخاص بك مثل أي عنصر HTML آخر.

<my-counter></my-counter>

سيقوم هذا الكود بعرض زر بعنوان "Increment" وعنصر span يعرض العد الحالي (بدءًا من 0). سيؤدي النقر فوق الزر إلى زيادة العداد وتحديث العرض.

التعمق أكثر: Shadow DOM والتغليف

يعتبر Shadow DOM جانبًا حاسمًا في مكونات الويب. إنه يوفر التغليف عن طريق إنشاء شجرة DOM منفصلة للمكون، وعزل تصميمه وسلوكه عن بقية الصفحة. هذا يمنع تعارض الأنماط ويضمن أن المكون يتصرف بشكل متوقع بغض النظر عن البيئة المحيطة.

داخل Shadow DOM، يمكنك تعريف أنماط CSS التي تنطبق فقط على العناصر الداخلية للمكون. يتيح لك ذلك إنشاء مكونات قائمة بذاتها لا تعتمد على أوراق أنماط CSS خارجية.

مثال: تنسيق Shadow DOM

constructor() {
 super();
 this.attachShadow({ mode: 'open' });

 // إنشاء عنصر style لـ shadow DOM
 const style = document.createElement('style');
 style.textContent = `
 button {
 background-color: #4CAF50;
 color: white;
 padding: 10px 20px;
 border: none;
 cursor: pointer;
 }
 span {
 margin-left: 10px;
 font-weight: bold;
 }
 `;
 this.shadowRoot.appendChild(style);

 // تهيئة قيمة العداد.
 this._count = 0;

 // إنشاء عنصر زر.
 this.button = document.createElement('button');
 this.button.textContent = 'Increment';
 this.shadowRoot.appendChild(this.button);

 // إنشاء عنصر span لعرض العد.
 this.span = document.createElement('span');
 this.span.textContent = `Count: ${this._count}`;
 this.shadowRoot.appendChild(this.span);

 // ربط دالة الزيادة بحدث النقر على الزر.
 this.button.addEventListener('click', this.increment.bind(this));
 }

في هذا المثال، ستنطبق أنماط CSS المعرفة داخل العنصر style فقط على عنصري الزر وspan داخل shadow DOM للمكون my-counter. لن تؤثر هذه الأنماط على أي أزرار أو عناصر span أخرى في الصفحة.

قوالب HTML: تعريف هياكل قابلة لإعادة الاستخدام

توفر قوالب HTML طريقة لتعريف هياكل HTML قابلة لإعادة الاستخدام يمكن استنساخها وإدراجها في DOM. وهي مفيدة بشكل خاص لإنشاء تخطيطات مكونات معقدة.

مثال: استخدام قوالب HTML

<template id="counter-template">
 <style>
 button {
 background-color: #4CAF50;
 color: white;
 padding: 10px 20px;
 border: none;
 cursor: pointer;
 }
 span {
 margin-left: 10px;
 font-weight: bold;
 }
 </style>
 <button>Increment</button>
 <span>Count: <span id="count-value">0</span></span>
</template>

<script>
class MyCounter extends HTMLElement {
 constructor() {
 super();
 this.attachShadow({ mode: 'open' });

 const template = document.getElementById('counter-template');
 const templateContent = template.content;
 this.shadowRoot.appendChild(templateContent.cloneNode(true));

 this.button = this.shadowRoot.querySelector('button');
 this.span = this.shadowRoot.querySelector('#count-value');
 this._count = 0;
 this.span.textContent = this._count;
 this.button.addEventListener('click', this.increment.bind(this));
 }

 increment() {
 this._count++;
 this.span.textContent = this._count;
 }
}

customElements.define('my-counter', MyCounter);
</script>

في هذا المثال، نعرّف قالب HTML بالمعرف counter-template. يحتوي القالب على بنية HTML وأنماط CSS لمكون العداد الخاص بنا. داخل الفئة MyCounter، نقوم باستنساخ محتوى القالب وإلحاقه بـ shadow DOM. يتيح لنا هذا إعادة استخدام بنية القالب لكل مثيل من المكون my-counter.

السمات (Attributes) والخصائص (Properties)

يمكن لمكونات الويب أن تحتوي على سمات (attributes) وخصائص (properties). يتم تعريف السمات في ترميز HTML، بينما يتم تعريف الخصائص في فئة جافاسكريبت. يمكن أن تنعكس التغييرات على السمات في الخصائص، والعكس صحيح.

مثال: تعريف واستخدام السمات

class MyGreeting extends HTMLElement {
 constructor() {
 super();
 this.attachShadow({ mode: 'open' });
 this.shadowRoot.innerHTML = `<p>Hello, <span id="name"></span>!</p>`;
 this.nameSpan = this.shadowRoot.querySelector('#name');
 }

 static get observedAttributes() {
 return ['name'];
 }

 attributeChangedCallback(name, oldValue, newValue) {
 if (name === 'name') {
 this.nameSpan.textContent = newValue;
 }
 }
}

customElements.define('my-greeting', MyGreeting);
<my-greeting name="World"></my-greeting>
<my-greeting name="Alice"></my-greeting>

في هذا المثال، نعرّف السمة name للمكون my-greeting. يخبر المُجلب observedAttributes المتصفح بالسمات التي يجب مراقبتها بحثًا عن التغييرات. عندما تتغير السمة name، يتم استدعاء الدالة attributeChangedCallback، ونقوم بتحديث محتوى العنصر span بالاسم الجديد.

ردود نداء دورة الحياة (Lifecycle Callbacks)

تحتوي مكونات الويب على العديد من ردود نداء دورة الحياة التي تتيح لك تنفيذ التعليمات البرمجية في مراحل مختلفة من دورة حياة المكون:

توفر ردود النداء هذه فرصًا لأداء التهيئة والتنظيف والمهام الأخرى المتعلقة بدورة حياة المكون.

توافق المتصفحات و Polyfills

مكونات الويب مدعومة من قبل جميع المتصفحات الحديثة. ومع ذلك، قد تتطلب المتصفحات القديمة polyfills لتوفير الوظائف اللازمة. توفر مكتبة polyfill webcomponents.js دعمًا شاملاً لمكونات الويب في المتصفحات القديمة. لتضمين polyfill، استخدم علامة البرنامج النصي التالية:

<script src="https://unpkg.com/@webcomponents/webcomponentsjs@2.6.0/webcomponents-loader.js"></script>

يوصى عمومًا باستخدام نهج اكتشاف الميزات، وتحميل polyfill فقط إذا كان المتصفح لا يدعم مكونات الويب بشكل أصلي.

تقنيات متقدمة وأفضل الممارسات

تركيب المكونات

يمكن تركيب مكونات الويب معًا لإنشاء عناصر واجهة مستخدم أكثر تعقيدًا. يتيح لك ذلك بناء تطبيقات معيارية وقابلة لإعادة الاستخدام بدرجة عالية.

معالجة الأحداث

يمكن لمكونات الويب إرسال والاستماع إلى أحداث مخصصة. يتيح هذا للمكونات التواصل مع بعضها البعض ومع بقية التطبيق.

ربط البيانات

على الرغم من أن مكونات الويب لا توفر آليات ربط بيانات مدمجة، يمكنك تنفيذ ربط البيانات باستخدام كود مخصص أو من خلال التكامل مع مكتبة ربط بيانات.

إمكانية الوصول

من المهم التأكد من أن مكونات الويب الخاصة بك متاحة لجميع المستخدمين، بمن فيهم ذوو الإعاقة. اتبع أفضل ممارسات إمكانية الوصول عند تصميم وتنفيذ مكوناتك.

مكونات الويب في العالم الحقيقي: أمثلة دولية

تُستخدم مكونات الويب من قبل الشركات والمؤسسات في جميع أنحاء العالم لبناء واجهات مستخدم حديثة وقابلة لإعادة الاستخدام. إليك بعض الأمثلة:

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

الخاتمة

توفر مكونات الويب نهجًا قويًا لبناء عناصر واجهة مستخدم قابلة لإعادة الاستخدام للويب الحديث. من خلال الاستفادة من العناصر المخصصة و shadow DOM وقوالب HTML، يمكنك إنشاء مكونات قائمة بذاتها يمكن استخدامها عبر مشاريع وأطر عمل مختلفة. يمكن أن يؤدي تبني مكونات الويب إلى تطبيقات ويب أكثر معيارية وقابلية للصيانة وقابلية للتوسع. مع تطور معايير الويب، ستستمر مكونات الويب في لعب دور حاسم في تشكيل مستقبل تطوير الويب.

لمزيد من التعلم

ابدأ بتجربة مكونات الويب اليوم واطلق العنان لقوة عناصر واجهة المستخدم القابلة لإعادة الاستخدام في مشاريع تطوير الويب الخاصة بك!