يعد نموذج كائن المستند (DOM) واجهة حيوية تسمح للمطورين بالتفاعل مع مستندات الويب باستخدام لغات البرمجة النصية مثل JavaScript. وهو يمثل عرضًا منظمًا وهرميًا ومنطقيًا لمحتويات مستند الويب، مثل HTML أو XML، كبنية تشبه الشجرة.
نشأة نموذج كائن المستند (DOM)
ظهر مفهوم DOM لأول مرة في منتصف وأواخر التسعينات نتيجة للحاجة إلى السماح بمزيد من محتوى الويب التفاعلي. مع ظهور مواقع الويب الديناميكية والاستخدام الواسع النطاق لجافا سكريبت، كانت هناك حاجة إلى نموذج يسمح للنصوص البرمجية بتغيير بنية المستند ونمطه ومحتواه. تولى اتحاد شبكة الويب العالمية (W3C) مهمة إنشاء واجهة برمجة تطبيقات موحدة لهذا الغرض، مما أدى إلى تطوير DOM.
تم تقديم أول مستوى DOM قياسي، DOM Level 1، بواسطة W3C في عام 1998. وقد قدم نموذجًا شاملاً لمستند HTML أو XML بأكمله، بما في ذلك وسائل تغيير أي جزء من المستند.
توسيع نموذج كائن المستند (DOM)
DOM هو في الأساس نظام أساسي وواجهة محايدة للغة تسمح للبرامج والبرامج النصية بالوصول ديناميكيًا إلى محتوى المستند وبنيته ونمطه وتحديثه.
يتم تنظيم DOM في تسلسل هرمي من العقد، تمثل كل منها جزءًا من المستند، مثل العناصر والسمات والنص. تسهل بنية الشجرة المنطقية هذه التنقل في محتويات المستند ومعالجتها.
يتم تصميم مستند الويب على شكل شجرة من الكائنات التي تتمتع جميعها بخصائص وطرق، ويمكن أن تحتوي على كائنات أخرى. على سبيل المثال، يتم تحويل مستند HTML إلى كائنات تمثل عناصر مثل "body" و"div" و"span" و"p"، بالإضافة إلى سماتها ومحتوى النص الخاص بها.
كيف يعمل نموذج كائن المستند (DOM).
يتم تنظيم البنية الداخلية لـ DOM على شكل شجرة من العقد. العقدة العليا هي Document
العقدة، التي تمثل الوثيقة بأكملها. وتحت هذا، Element
تتوافق العقد مع عناصر HTML الموجودة في الصفحة، Attribute
العقد تحمل سمات العناصر، و Text
العقد تحمل محتوى نص العناصر.
يسمح هذا الهيكل الهرمي للمطورين بالتنقل في شجرة المستندات واستخدام أساليب API لتحديد العقد أو إنشائها أو تعديلها أو حذفها.
فيما يلي مثال لكيفية ظهور مستند HTML كشجرة DOM:
الرياضياتDocument
↳ Element: html
↳ Element: head
↳ Element: title
↳ Text: "Title of the Document"
↳ Element: body
↳ Element: h1
↳ Text: "Hello, world!"
↳ Element: p
↳ Text: "This is a paragraph."
الميزات الرئيسية لنموذج كائن المستند (DOM)
-
هيكل الشجرة: يمثل DOM مستندًا في بنية شجرة منطقية، مما يجعل التنقل والاختيار والمعالجة أمرًا مباشرًا وبديهيًا.
-
لغة محايدة: DOM غير مرتبط بأي لغة برمجة معينة. إنه تقليد لتمثيل الكائنات والتفاعل معها في HTML وXML وأنواع المستندات الأخرى.
-
الوصول الديناميكي والتحديث: يسمح DOM للبرامج بالوصول ديناميكيًا إلى محتوى المستند وبنيته ونمطه وتحديثه.
-
موحدة: DOM هو معيار W3C، مما يضمن قبوله وتوافقه على نطاق واسع عبر المتصفحات والأنظمة الأساسية المختلفة.
أنواع نموذج كائن المستند (DOM)
تنقسم مواصفات DOM إلى عدة "مستويات" و"وحدات"، كل منها يضيف ميزات ووظائف إلى سابقتها. تشمل الأنواع الرئيسية ما يلي:
مستوى/نوع DOM | وصف مختصر |
---|---|
دوم المستوى 1 | توفير نموذج أساسي لمستندات HTML أو XML بأكملها، بما في ذلك طرق التعامل مع العناصر وسماتها. |
دوم المستوى 2 | تم تقديم ميزات مثل معالجة مساحة الاسم، ووحدة النمط التي تدعم CSS، والعديد من الواجهات الجديدة للتعامل مع الجداول والأحداث وما إلى ذلك. |
دوم المستوى 3 | تمت إضافة دعم لـ XPath ومعالجة أحداث لوحة المفاتيح، وتقديم واجهات لتحميل المستندات وحفظها. |
دوم المستوى 4 | تم تبسيط DOM الأساسي عن طريق تقليل التبعيات، وتقديم وعود للعمليات غير المتزامنة، وإضافة المزيد من الميزات مثل الميزات الأبوية لتسهيل معالجة العقد. |
استخدام نموذج كائن المستند (DOM)
يتم استخدام DOM في كل مرة يتم فيها التعامل مع صفحة الويب باستخدام JavaScript. إنها واجهة برمجة التطبيقات الأساسية للعديد من تقنيات الويب.
يستخدم المطورون DOM لتغيير شكل صفحة الويب ومظهرها ومحتواها ديناميكيًا دون الحاجة إلى إعادة تحميل الصفحة بالكامل، مما يسمح بواجهات مستخدم تفاعلية وسريعة الاستجابة.
على الرغم من قوته، إلا أن DOM لا يخلو من المشاكل. يمكن أن يصبح بطيئًا إذا لم يتم استخدامه بعناية، خاصة مع مستندات الويب الكبيرة أو المعقدة. يمكن أن يؤدي التعامل مع DOM بشكل سيئ إلى بطء عرض الصفحة وعدم استجابة الواجهات. لمعالجة هذه المشكلة، غالبًا ما يستخدم المطورون مكتبات أو أطر عمل مثل jQuery أو React أو Vue.js، والتي توفر واجهات برمجة تطبيقات عالية المستوى لمعالجة DOM بكفاءة.
خصائص DOM والمقارنة مع المصطلحات المماثلة
شرط | وصف | مقارنة |
---|---|---|
DOM | واجهة برمجة التطبيقات (API) لمستندات HTML وXML، مما يوفر تمثيلاً هيكليًا للمستند ويسمح للمطورين بمعالجة محتواه وعرضه المرئي. | |
CSSOM | نموذج كائن CSS (CSSOM) عبارة عن خريطة لأنماط CSS، تشبه DOM ولكنها مخصصة لـ CSS. يسمح بمعالجة أوراق الأنماط والأنماط المطبقة على DOM. | بينما يركز DOM على بنية المستند، يركز CSSOM على طبقة العرض. |
الظل دوم | آلية لتغليف أجزاء من شجرة DOM لتنفيذ مكونات الويب. فهو يعزل أجزاء من DOM "لإخفائها" عن شجرة المستندات الرئيسية. | على عكس DOM العادي، يوفر Shadow DOM تغليفًا للأسلوب والسلوك. |
وجهات النظر المستقبلية المتعلقة بنموذج كائن المستند (DOM)
مع استمرار تطور تقنيات الويب، من المرجح أيضًا أن تتوسع واجهة DOM API وتتحسن. تتضمن التطورات المستقبلية المحتملة طرقًا أكثر كفاءة للتعامل مع DOM، وتحسين التكامل مع معايير الويب الناشئة، والتطور المستمر لمواصفات HTML نفسها.
التطور المستمر المثير للاهتمام هو الاعتماد المتزايد لمكونات الويب، والذي يسمح بإنشاء علامات HTML مغلفة وقابلة لإعادة الاستخدام. ويرتبط هذا ارتباطًا وثيقًا بـ Shadow DOM، الذي يوفر طريقة لتغليف عناصر DOM.
نموذج كائن المستند (DOM) والخوادم الوكيلة
الخادم الوكيل هو وسيط يقوم بإعادة توجيه الطلبات والاستجابات بين العميل والخادم. في حين أن DOM يهتم في المقام الأول ببنية ومعالجة مستندات الويب من جانب العميل، فإن خوادم الوكيل تعمل على مستوى الشبكة.
ومع ذلك، يمكن العثور على التقاطع بين الاثنين في السيناريوهات التي قد يقوم فيها الخادم الوكيل بتعديل محتويات مستند الويب. على سبيل المثال، يمكن للخادم الوكيل إضافة عناصر DOM أو إزالتها أو تعديلها في صفحة ويب قبل أن يصل إلى العميل. ويمكن استخدام ذلك لعدة أسباب، مثل إدخال البرامج النصية، أو إزالة العناصر غير المرغوب فيها، أو تعديل المحتوى لأغراض الترجمة أو التخصيص.
روابط ذات علاقة
- MDN Web Docs: نموذج كائن المستند (DOM)
- معيار W3C دوم
- معلومات جافا سكريبت: DOM
- أساسيات الويب من Google: كيف تعمل المتصفحات
يجب أن توفر هذه النظرة العامة فهمًا شاملاً لنموذج كائن المستند (DOM) وأصله وكيفية عمله وخصائصه وكيف من المحتمل أن يتطور. يظل DOM حجر الزاوية في تطوير الويب التفاعلي وسيستمر في لعب دور حاسم مع تقدم تقنيات الويب.