Современные методы DOM-навигации в JavaScript

Для манипуляции HTML-элементами в JavaScript предпочтительно использовать методы querySelector() и querySelectorAll(). Они принимают CSS-селекторы, что упрощает работу для фронтенд-разработчиков. Метод querySelector() возвращает первый подходящий элемент или null, в то время как querySelectorAll() возвращает NodeList со всеми подходящими элементами или пустой NodeList, если совпадений нет.
Современные методы DOM-навигации в JavaScript
Изображение носит иллюстративный характер

Помимо поиска элементов, класс Element имеет полезный метод matches(), который проверяет соответствие элемента заданному селектору. Для поиска родительских элементов существует метод closest(), который также принимает селектор и возвращает ближайший родительский элемент, соответствующий этому селектору.

Старые методы поиска элементов, такие как getElementById(), getElementsByTagName(), getElementsByName(), и getElementsByClassName(), могут создавать путаницу из-за их различий в поведении. Они возвращают NodeList или HTMLCollection (кроме getElementById(), который возвращает элемент), которые могут быть активными, меняя свою длину при изменении DOM. Эти методы лучше избегать, чтобы упростить код.

Перемещение по DOM относительно элемента можно выполнить через свойства, такие как parentNode, children, firstElementChild, lastElementChild, nextElementSibling и previousElementSibling. Эти свойства игнорируют текстовые узлы и комментарии, что позволяет сосредоточиться на HTML-структуре. Свойство childElementCount позволяет узнать количество дочерних элементов.


Новое на сайте

20072Эффект красоты решает исход собеседования до первых слов 20069Как черта характера крадёт деньги на переговорах 20068Карточная игра против главной дисфункции команды 20067Какие три нарратива способны провести компанию сквозь любой кризис? 20066Фотосинтез в глазах мышей: возможно ли это без превращения в растение? 20065СПКЯ стало СПМЯ: почему переименование болезни, затрагивающей миллионы женщин, заняло так... 20064Почему великая пирамида Гизы пережила все землетрясения за 4500 лет 20063Генетика Homo erectus: что зубная эмаль рассказала о наших предках 20062Кости в бухте Эребус: что кости моряков Франклина рассказывают спустя полтора века 20061Крупнейший плавучий ветрогенератор в мире: Китай испытывает установку у берегов Шанхая 20060Карие глаза младенца стали индиго после лечения от COVID-19 20058Почему серебряная чаша с Афиной пролежала в немецком лесу две тысячи лет? 20057Дыра в атмосфере солнца: вспышка достигла пика и может зажечь полярное сияние 20056Динго возрастом 950 лет: кто и зачем кормил могилу животного сотни лет?
Ссылка