در مقدمه این سری آمده است: "عناصر HTML گره هایی هستند که مدل شیء سند را می سازند." ما در مورد نوع گره های عنصر بحث کرده ایم. در این بخش، APIهای عنصری را مورد بحث قرار میدهیم که امکان پرسوجو از آن گرهها را فراهم میکنند.
DOM و AOM
DOM یک API برای دسترسی و دستکاری اسناد است. DOM درخت تمام گره های سند است. برخی از گره ها می توانند فرزند داشته باشند، برخی دیگر نمی توانند. درخت شامل عناصر به همراه ویژگی های آنها و گره های متنی است.

ابزارهای مرورگر تجسم درختی مانند تصویر بالا را ارائه نمی دهند، اما می توانید گره ها را در بازرس عنصر مشاهده کنید.

نمایش درختی که می تواند در ابزارهای توسعه دهنده مرورگر بررسی شود درخت دسترسی است. AOM بر اساس DOM است. به طور مشابه، درخت دسترسی شامل اشیایی است که تمام عناصر نشانه گذاری، ویژگی ها و گره های متن را نشان می دهد:

APIهای عناصر HTML
حرف وسط DOM "ابجکت" است. درست مانند مثال شی person یا car از بیشتر کلاس های برنامه نویسی مقدماتی تا شی گرا، هر گره در درخت سند یک شی است که می تواند با جاوا اسکریپت دستکاری شود.
این مرورگر API های متعددی را ارائه می دهد که روش ها، رویدادها و پرس و جو و به روز رسانی دارایی ها را پشتیبانی می کند. گره های عنصر حاوی اطلاعاتی در مورد تمام ویژگی های تنظیم شده روی عنصر هستند. شما می توانید از رابط های HTML برای دسترسی به اطلاعات مربوط به ویژگی های یک عنصر استفاده کنید. به عنوان مثال، میتوانیم از HTMLImageElement.alt برای دریافت ویژگیهای alt همه تصاویر استفاده کنیم:
let allImages = document.querySelectorAll('img');
allImages.forEach((imageInstance) => {
console.log(imageInstance.alt);
});
رابط های HTML چیزی بیش از دسترسی به ویژگی های یک عنصر را فراهم می کنند. شما می توانید به اطلاعات بسیار بیشتری دسترسی داشته باشید. ما میتوانیم HTMLElement.offsetHeight فقط خواندنی را پیدا کنیم تا ارتفاع هر بخش در صفحه خود را نسبت به طرحبندی به دست آوریم.
let allSections = document.querySelectorAll('section');
allSections.forEach((sectionInstance) => {
console.log(sectionInstance.offsetHeight);
});
اگر کاربر جهت دستگاه خود را تغییر دهد یا عرض نمای پورت را تغییر دهد، ارتفاع هر <section> تغییر می کند و ویژگی های DOM به طور خودکار با آن به روز می شوند.
APIهای رابط HTML محدود به دسترسی به مقادیر ویژگی نیست. DOM بینشی از وضعیت فعلی UI ارائه می دهد. API های HTML می توانند به تمام آن اطلاعات دسترسی داشته باشند. میتوانید به طول یک ویدیو دسترسی داشته باشید، جایی که یک نما در پخش فعلی است، و اگر پخش ویدیو (یا صدا) به ترتیب با HTMLMediaElement.duration ، HTMLMediaElement.currentTime و HTMLMediaElement.ended تمام شده باشد.
رابط های عناصر موجود
اکثر عناصر HTML که تاکنون در این مجموعه پوشش دادهایم و هنوز پوشش ندادهایم، به غیر از برخی عناصر بخشبندی ، یک رابط DOM مرتبط دارند. رابط پایه برای همه عناصر به درستی Element نام دارد. HTMLElement از Element و تمام واسط های خاص عنصر HTML از آن ارث می برند. برخی از رابط های خاص عنصر توسط چندین عنصر مشابه پیاده سازی می شوند.
رابط ها عبارتند از:
-
HTMLAnchorElement-<a> -
HTMLAreaElement-<area> -
HTMLAudioElement-<audio> -
HTMLBaseElement-<base> -
HTMLButtonElement-<button> -
HTMLCanvasElement-<canvas> -
HTMLDataElement-<data> -
HTMLDataListElement-<datalist> -
HTMLDetailsElement-<details> -
HTMLDialogElement-<dialog> -
HTMLEmbedElement-<embed> -
HTMLFieldSetElement-<fieldset> -
HTMLFormElement-<form> -
HTMLHtmlElement-<html> -
HTMLIFrameElement-<iframe> -
HTMLImageElement-<img> -
HTMLInputElement-<input> -
HTMLLabelElement-<label> -
HTMLLegendElement-<legend> -
HTMLLIElement-<li> -
HTMLLinkElement-<link> -
HTMLMapElement-<map> -
HTMLMediaElement-<audio>،<video> -
HTMLMenuElement-<menu> -
HTMLMetaElement-<meta> -
HTMLMeterElement-<meter> -
HTMLModElement-<ins>،<del> -
HTMLObjectElement-<object> -
HTMLOListElement-<ol> -
HTMLOptGroupElement-<optgroup> -
HTMLOptionElement-<option> -
HTMLOutputElement-<output> -
HTMLPictureElement-<picture> -
HTMLProgressElement-<progress> -
HTMLQuoteElement-<q>،<blockquote>،<cite> -
HTMLScriptElement-<script> -
HTMLSelectElement-<select> -
HTMLSlotElement-<slot> -
HTMLSourceElement-<source> -
HTMLStyleElement-<style> -
HTMLTableCellElement-<td>،<th> -
HTMLTableColElement-<col>،<colgroup> -
HTMLTableElement-<table> -
HTMLTableRowElement-<tr> -
HTMLTableSectionElement-<thead>،<tbody>،<tfoot> -
HTMLTemplateElement-<template> -
HTMLTextAreaElement-<textarea> -
HTMLTimeElement-<time> -
HTMLTitleElement-<title> -
HTMLTrackElement-<track> -
HTMLVideoElement-<video>
قرارداد نامگذاری "HTML" است که به دنبال یک عنصر یا گروه بندی عناصر در حروف شتر بالایی و به دنبال آن "Element" است، اما بخش عنصر یا گروه بندی عناصر از الگوی دقیقی پیروی نمی کند. نگران نباشید. نیازی به حفظ کردن اینها نیست. فقط مهم است که بدانید آنها وجود دارند تا بتوانید در صورت نیاز آنها را جستجو کنید.
اگر مجموعه ای از عناصر دارید، رابط های مجموعه ای نیز وجود دارد. به عنوان مثال، متد HTMLCollection.namedItem() اولین عنصر را در مجموعه که ویژگی id یا name آن با پارامتر مطابقت دارد، برمیگرداند یا اگر هیچ عنصری مطابقت نداشته باشد null را برمیگرداند.
بیش از 30 عنصر یک رابط DOM مرتبط غیر از HTMLElement از جمله <address> ، <article> ، <section> ، <nav> ، <header> ، <footer> ، <aside> و <hgroup> ندارند. بسیاری از عناصری که از هیچ ویژگی غیرمنسوخ و غیر جهانی پشتیبانی نمیکنند، دارای رابطهای خاص عنصر هستند، مانند HTMLPElement (عنصر <p> ) و HTMLUnknownElement ( <😃> یا هر عنصر دیگری که تعریف نشده است)، اما این رابطها فاقد آن هستند. هیچ ویژگی یا روش اضافی را در بالای ویژگی ها و روش های به ارث رسیده از HTMLElement پیاده سازی نکنید، و در بالا ذکر نشده اند.
روش ها و ویژگی های اضافی API
اگر یک رابط دارای روش یا نام خاصیت مشابه با رابطی باشد که به ارث میبرد، متد یا ویژگی ارث بری، روش ارثی را بازنویسی میکند. به عبارت دیگر، روشها و ویژگیهای والدین بر فرزندان غلبه میکنند. وقتی به ویژگیهای alt و offsetHeight در APIهای عنصر HTML با imageInstance.alt و sectionInstance.offsetHeight به ترتیب دسترسی پیدا کردیم، کد مشخص نمیکرد به کدام API دسترسی داشت. به طور کلی، مانند این دو مثال، این یک مسئله نیست.
با این حال، مواردی وجود دارد که افزونگی می تواند مشکل ایجاد کند. به عنوان مثال، HTMLCollection.length فقط خواندنی است، در حالی که رابط ارث بری، HTMLOptionsCollection ، دارای یک ویژگی طولی است (که فقط با ویژگی options های <select> برگردانده می شود) با دسترسی خواندن و نوشتن. برای تنظیم اندازه مجموعه می توان از HTMLOptionsCollection استفاده کرد.
سایر رابط ها
اینترفیس های اضافی وجود دارد که امکان دستکاری مکان های شاخه گره های DOM را فراهم می کند. رابط EventTarget که به ما با addEventListener() و removeEventListener() ارائه می کند، توسط رابط های Node و Window به ارث می رسد. به نوبه خود، رابط های Element، Document و DocumentFragment (که در عناصر سفارشی دیدیم) از Node و رابط HTMLElement از Element ارث می برند.
رابط node
هر نوع گره DOM توسط یک رابط مبتنی بر Node نشان داده می شود که اطلاعات و روش هایی را به عنوان عناصر مربوط به درخت DOM ارائه می دهد. رابط Node امکان پرس و جو و افزودن گره ها به درخت گره را فراهم می کند.
تابع معروف داگلاس کراکفورد "walk the DOM" از ویژگی های firstChild و nextSibling Node استفاده می کند.
const walk_the_DOM = function walk(node, callback) {
callback(node);
node = node.firstChild;
while (node) {
walk(node, callback);
node = node.nextSibling;
}
};
ما از متدهای appendChild() و cloneNode() Node در تعریف عناصر سفارشی استفاده کردیم. رابط Node ویژگی ها و روش های مفید بسیاری را برای پرس و جو و دستکاری DOM ارائه می دهد.
customElements.define('star-rating',
class extends HTMLElement {
constructor() {
super(); // Always call super first in constructor
const starRating = document.getElementById('star-rating-template').content;
const shadowRoot = this.attachShadow({
mode: 'open'
});
shadowRoot.appendChild(starRating.cloneNode(true));
}
});
متد attachShadow() متدی از رابط Element است. همچنین یک رابط shadowRoot برای Shadow DOM API وجود دارد که جدا از درخت DOM اصلی سند ارائه شده است.
رابط های Document و HTMLDocument
رابط Document از Node به ارث می رسد. این نشان دهنده صفحه وب بارگذاری شده در مرورگر است، خواه سند HTML، SVG، XML، MathML یا موارد دیگر باشد. رابط Document نیز از رابط HTMLDocument به ارث می رسد.
این document دسترسی سریع به انواع گره ها و توانایی ایجاد مجموعه هایی از انواع عناصر خاص، مانند document.body و document.styleSheets را امکان پذیر می کند. HTMLDocument دسترسی به اطلاعات مربوط به سند را که در گرههای HTML یافت نمیشوند، مانند Document.location ، Document.lastModified ، و Document.Cookie را امکانپذیر میسازد.
چندین API بر اساس ویژگیهایی که از طریق رابط سند ظاهر میشوند، از جمله Drag and Drop API و FullScreen API در دسترس هستند. هر دو از Element ارث می برند.
رابط Window
رابط Window شامل موارد در دسترس جهانی فراتر از DOM است که می تواند برای دستکاری DOM استفاده شود. Window توابع، فضاهای نام، اشیاء و سازنده های مستند شده در منابع جاوا اسکریپت و DOM MDN را ارائه می دهد.
رابط Window API برای شی حاوی سند است. شی window جهانی پنجره ای است که اسکریپت در آن اجرا می شود. هر برگه مرورگر حاوی شی پنجره مخصوص به خود است. رابط Window می تواند محتویات برگه و همچنین پنجره کلی و دستگاه را پرس و جو کند. به عنوان مثال، از متد resizeTo() می توان برای تغییر اندازه پنجره مرورگر استفاده کرد، ویژگی devicePixelRatio دسترسی به پیکسل های نمایشگر دستگاه را فراهم می کند. هنگام دسترسی به اطلاعات مربوط به برگه ای که محتوا در آن قرار دارد به جای درخت DOM که برگه نمایش داده می شود، پنجره احتمالاً رابطی است که به دنبال آن هستید.
چندین API بر اساس ویژگی های ظاهر شده از طریق رابط Window در دسترس هستند، از جمله Web Workers و IndexedDB API.
درک خود را بررسی کنید
دانش خود را از API های HTML تست کنید.
O در DOM مخفف چیست؟
کدام رابط می تواند به شما کمک کند تا اطلاعات مربوط به برگه ای که محتوا در آن قرار دارد را بیابید؟