Метод querySelectorAll в JavaScript
В данной статье мы продолжим изучать функции querySelector и querySelectorAll. Про querySelector я уже рассказывал в этой статье, поэтому сейчас я расскажу вам про вторую.
Функция querySelectorAll возвращает все, что соответствует переданному ей css селектору:
let elements = document.querySelectorAll("CSS селектор");
За исключением числа возвращаемых элементов, все, что я описывал в отношении querySelector в предыдущей статье, также относится и к querySelectorAll . Запомните лишь то, что данная функция не возвращает один элемент - вместо этого возвращается массив элементов!
Используя уже известный пример HTML кода из прошлой статьи, если мы хотим использовать querySelectorAll, чтобы отобразить атрибут src для всех элементов img , у которых значение класса img-src, нужно сделать следующее:
let images = document.querySelectorAll(".img-src");
for (let i = 0; i < images.length; i++)
{
let image = images[i];
alert(image.getAttribute(src));
}
Смотрите, как просто. Единственное, что вам нужно- это помнить, как работать с массивами в JavaScript.
Фишка querySelector и querySelectorAll, состоит в том, что они фактически используют весь диапазон вариантов синтаксиса селекторов CSS в качестве аргумента.
Если вы хотите получить все элементы img без указания значения класса, вот как можно это сделать с помощью querySelectorAll:
let images = document.querySelectorAll("img");
Если вы хотите выбрать только изображение, чей атрибут src установлен на meh.png , вы можете сделать следующее:
let images = document.querySelectorAll("img[src='meh.png']");
Обратите внимание, что в качестве аргумента querySelectorAll я просто определил селектор атрибутов. Практически любое сложное выражение, которое вы можете указать для селектора в файле CSS стилей, является справедливым и для указания в качестве аргумента либо для querySelector, либо для querySelectorAll.
Однако есть некоторые ограничения, о которых вы должны знать:
- Не все селекторы псевдокласса допускаются. Селекторы, состоящие из :visited или :link , игнорируется и, соответственно, элементы не будут найдены.
- Как далеко вы сможете продвинуться в использовании выбранных вами селекторов, зависит от поддержки той или иной особенности CSS браузером. Internet Explorer 8 поддерживает querySelector и querySelectorAll . Но он не поддерживает CSS3. Учитывая это, использование новшеств, предоставляемых CSS3, не будет иметь никакого эффекта.
- Указанный вами селектор применяется только к потомкам элемента, с которого вы начинаете поиск. Сам исходный элемент в итоговый результат включен не будет.
Таким образом, функции querySelector и querySelectorAll чрезвычайно полезны в ситуациях, где выборка определенного элемента часто является сложной задачей. Если мне нужны все элементы изображения, я могу просто написать querySelectorAll("img").Если мне нужен только непосредственный элемент img, содержащийся внутри его родительского div , я могу написать querySelector ("div + img").
А как насчет getElementById, getElementsByTagName, getElementsByClassName?
В прошлом, для выборки элементов страницы использовались функции getElementById , getElementsByTagName и getElementsByClassName. И, несмотря на то, что Вы все еще можете видеть эти функции в старых книгах, учебниках и статьях, вы должны просто использовать querySelector и querySelectorAll. Эти две функции проще в использовании и намного мощнее, чем то, что вы можете сделать с функциями getElement*.
Как однажды сказал мудрый человек, жизнь слишком коротка, чтобы тратить время на изучение старых функций JavaScript.
На этом все, всего доброго!
-
- Михаил Русаков
Комментарии (0):
Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.