.querySelector() — JavaScript — Дока
- Кратко
- Как пишется
- Как понять
- На практике
- Николай Лопин советует
Кратко
Скопировано
Метод определён для объекта document
и любого HTML-элемента (Element
) страницы. Позволяет найти элемент по CSS-селектору среди дочерних. Если элементов несколько, то вернётся первый подходящий. Если подходящих элементов нет, то вернёт null
.
Как пишется
Скопировано
Метод принимает один параметр — CSS-селектор в виде строки. Если передан не CSS-селектор, то система выбросит ошибку. Например, можно выбрать первый элемент внутри <div>
:
<body> <div> <p> Князь Василий говорил всегда лениво, как актер говорит роль старой пиесы. Анна Павловна Шерер, напротив, несмотря на свои сорок лет, была преисполнена оживления и порывов. </p> <p> Быть энтузиасткой сделалось её общественным положением, и иногда, когда ей даже того не хотелось, она, чтобы не обмануть ожиданий людей, знавших её, делалась энтузиасткой. Сдержанная улыбка, игравшая постоянно на лице Анны Павловны, хотя и не шла к её отжившим чертам, выражала, как у избалованных детей, постоянное сознание своего милого недостатка, от которого она не хочет, не может и не находит нужным исправляться. </p> </div> <p>Это параграф, дочерний для body</p> <script> const firstParagraph = document.querySelector('div > p') console.log(firstParagraph.textContent) // напечатает текст, начинающийся с 'Князь Василий' // ищем несуществующий элемент const spanFromBody = document.querySelector('span') console.log(spanFromBody) // null </script></body>
<body>
<div>
<p>
Князь Василий говорил всегда лениво, как актер говорит роль старой
пиесы. Анна Павловна Шерер, напротив, несмотря на свои сорок лет, была
преисполнена оживления и порывов.
</p>
<p>
Быть энтузиасткой сделалось её общественным положением, и иногда, когда
ей даже того не хотелось, она, чтобы не обмануть ожиданий людей, знавших
её, делалась энтузиасткой. Сдержанная улыбка, игравшая постоянно на лице
Анны Павловны, хотя и не шла к её отжившим чертам, выражала, как у
избалованных детей, постоянное сознание своего милого недостатка, от
которого она не хочет, не может и не находит нужным исправляться.
</p>
</div>
<p>Это параграф, дочерний для body</p>
<script>
const firstParagraph = document.querySelector('div > p')
console.log(firstParagraph.textContent)
// напечатает текст, начинающийся с 'Князь Василий'
// ищем несуществующий элемент
const spanFromBody = document.querySelector('span')
console.log(spanFromBody)
// null
</script>
</body>
Динамический пример, введите селектор в поле поиска и нажмите «Искать»:
Открыть демо в новой вкладкеКак понять
Скопировано
Метод работает с DOM, который связан с HTML-разметкой. Каждый HTML-элемент имеет родительские и дочерние элементы:
- Родители — это элементы, которые содержат текущий элемент. В примере выше у первого элемента
<p>
есть два родительских элемента —<div>
и<body>
. - Дочерние элементы — это элементы, которые содержит текущий элемент. Они могут быть, а могут не быть. Например, для тега
<body>
все элементы страницы дочерние. У<p>
дочерний элемент — текст внутри тега.
Если вы работаете с корнем страницы, объектом document
, то поиск идёт по всем элементам страницы (от <body>
), если от конкретного элемента, то поиск идёт только по всем дочерним.
На практике
Скопировано
Николай Лопин советует
Скопировано
🛠 Для поиска первого элемента в DOM нужно передать строку '*'
аргументом query
, её называют wildcard.
Если вы нашли ошибку, отправьте нам пул-реквест!
Во время отправки формы что-то пошло не так. Попробуйте ещё раз?
←
.get
ctrl + alt + ←
→
.query
ctrl + alt + →
Селекторы — Учебник CSS — schoolsw3.com
❮ Назад Далее ❯
Селекторы
Селекторы CSS используются для «поиска» (или выбора) HTML элементов, которым вы хотите задать стиль.
Мы можем разделить CSS селекторы на пять категорий:
- Простые селекторы (выбор элементов на основе Имени, Идентификатора и Класса)
- Комбинированные селектора (выбор элементов на основе определенной взаимосвязи между ними)
- Псевдоклассы селекторов (выбор элементов на основе определенного состояния)
- Псевдоэлементы селекторов (выбор и стиль части элемента)
- Атрибуты селекторов (выбор элементов на основе атрибута или значения атрибута)
На этой странице будут объяснены самые основные CSS селекторы.
CSS Селектор элементов
Селектор элементов выбирает HTML элементы на основе имени элемента.
Пример
Здесь все элементы <p> на странице будут выровнены по центру, с красным цветом текста:
p
{
text-align: center;
color: red;
}
Попробуйте сами »
CSS Селектор идентификаторов
Селектор идентификаторов использует атрибут идентификатора HTML элемента для выбора конкретного элемента.
Идентификатор элемента уникален в пределах страницы, поэтому селектор идентификаторов используется для выбора одного уникального элемента!
Чтобы выбрать элемент с определенным идентификатором, напишите символ хэша ( # ), за которым следует идентификатор элемента.
Пример
Приведенное ниже правило CSS будет применено к HTML элементу:
#para1
{
text-align: center;
color: red;
}
Попробуйте сами »
Примечание: Идентификационное имя не может начинаться с цифры!
CSS Селектор классов
Селектор классов выбирает HTML элементы с определенным атрибутом класса.
Чтобы выбрать элементы с определенным классом, напишите символ точки (.), за которым следует имя класса.
Пример
В этом примере все HTML элементы с будет красным и выровненным по центру:
.center {
text-align: center;
color: red;
}
Попробуйте сами »
Вы также можете указать, что класс должен влиять только на определенные HTML элементы.
Пример
В этом примере только элементы <p> с будет выровнен по центру:
p.center {
text-align: center;
color: red;
}
Попробуйте сами »
HTML элементы также могут ссылаться на несколько классов.
Пример
В этом примере элемент <p> будет задан стиль в соответствии с и:
<p>Этот параграф относится к двум классам.</p>
Попробуйте сами »
Примечание: Имя класса не может начинаться с цифры!
CSS Селектор универсальный
Универсальный селектор (*) выбирает все HTML элементы на странице.
Пример
Приведенное ниже правило CSS повлияет на каждый HTML элемент на странице:
*
{
text-align: center;
color: blue;
}
Попробуйте сами »
CSS Группировка селекторов
Группировка селекторов выбирает все HTML элементы с одинаковым определенным стилем.
Посмотрите на следующий код CSS (элементы h2, h3, и p имеют одинаковые определения стилей):
h2
{
text-align: center;
color: red;
}
h3
{
text-align: center;
color: red;
}
p
{
color: red;
}
Будет лучше сгруппировать селекторы, чтобы минимизировать код.
Чтобы сгруппировать селекторы, разделите их запятыми.
Пример
В этом примере мы сгруппировали селекторы из приведенного выше кода:
h2, h3, p
{
text-align: center;
color: red;
}
Попробуйте сами »
CSS Упражнения
Проверьте себя с помощью упражнений
Упражнение::
Установите цвет всех элементов <p> на красный.
<style> { red; } </style>
Все простые селекторы CSS
Селектор | Пример | Пример описание |
---|---|---|
.class | .intro | Выбирает все элементы с помощью |
#id | Выбирает элемент с помощью | |
* | * | Выбирает все элементы |
element | p | Выбирает все элементы <p> |
element,element,.. | div, p | Выбирает все элементы <div> и <p> |
❮ Назад Далее ❯
Селекторы W3.JS
❮ Назад Далее ❯
Селекторы W3.JS
W3.JS выбирает элементов HTML и выполняет действий над выбранными элементами:
w3. действие ( селектор )
- Действие () выполняется на выбранных элементах
- ( селектор ) выбирает элемент(ы) HTML
Пример
w3.hide(‘p’) // Скрыть все элементы
Попробуй сам » С помощью CSS »
Знакомы ли вы с селекторами CSS?
W3.JS использует синтаксис CSS для выбора элементов HTML и управления ими.
Селекторы используются для «поиска» (выбора) HTML-элементов на основе имени их тега, id, классы, типы, атрибуты, значения атрибутов и многое другое. Список все селекторы можно найти в нашем селекторе CSS Ссылка.
Примеры селекторов
Чтобы выбрать элементы HTML, используйте имя тега:
Скрыть все элементы
:
w3.hide(‘h3’)
Попробуй сам »
Чтобы выбрать элемент с определенным идентификатором, напишите символ решетки, а затем идентификатор HTML-элемента:
Скройте элемент с помощью:
w3. hide(‘#London’)
Попробуй сам »
Чтобы выбрать элементы с определенным классом, напишите символ точки, а затем имя класса:
Скрыть все элементы с помощью:
w3.hide(‘.city’)
Попробуй сам »
Дополнительные примеры селекторов
Селектор | Описание | Пример |
---|---|---|
(«*») | Выбирает все элементы в документе | Попробуйте |
(этот) | Выбирает текущий элемент HTML | Попробуйте |
(«вступление») | Выбирает все элементы с | Попробуйте |
(«дел п») | Выбирает все элементы внутри всех элементов | Попробуйте |
(«дел p:первый-потомок») | Выбирает первый элемент внутри всех элементов | Попробуйте |
(«[ссылка]») | Выбирает все элементы с атрибутом href | Попробуйте |
(«а[цель=_пусто]») | Выбирает все элементы со значением целевого атрибута, равным «_blank» | Попробуйте |
(«p:nth-ребенок(четный)») | Выбирает все четные элементы | Попробуйте |
Полную информацию обо всех селекторах CSS см. в нашем Справочнике по селекторам CSS.
❮ Предыдущий Следующий ❯
ВЫБОР ЦВЕТА
Лучшие учебники
Учебник HTMLУчебник CSS
Учебник JavaScript
Учебник How To
Учебник SQL
Учебник Python
Учебник по W3.CSS
Учебник по Bootstrap
Учебник по PHP
Учебник по Java
Учебник по C++
Учебник по jQuery
Основные ссылки
HTML ReferenceCSS Reference
JavaScript Reference
SQL Reference
Python Reference
W3.CSS Reference
Bootstrap Reference
PHP Reference
HTML Colors
Java Reference
Angular Reference
jQuery Reference
5 Top5 Examples Примеры HTML
Примеры CSS
Примеры JavaScript
Примеры инструкций
Примеры SQL
Примеры W3.CSS
Примеры Bootstrap
Примеры PHP
Примеры Java
Примеры XML
Примеры jQuery
FORUM | О
W3Schools оптимизирован для обучения и обучения. Примеры могут быть упрощены для улучшения чтения и обучения. Учебники, ссылки и примеры постоянно пересматриваются, чтобы избежать ошибок, но мы не можем гарантировать полную правильность всего содержания. Используя W3Schools, вы соглашаетесь прочитать и принять наши условия использования, куки-файлы и политика конфиденциальности.
Copyright 1999-2023 Refsnes Data. Все права защищены.
W3Schools использует W3.CSS.
Объяснение селекторов DOM. Понимание селекторов DOM для написания… | by Mano lingam
Использование селекторов DOMЕсли вы читаете эту статью, то вы должны быть знакомы с DOM (объектной моделью документа). Итак, давайте начнем с селекторов DOM, не тратя время на объяснение того, что такое DOM.
Селекторы DOM, как следует из названия, используются для выбора HTML-элементов в документе с помощью JavaScript. Существует 5 способов выбора элементов в DOM с помощью селекторов.
- getElementsByTagName()
- getElementsByClassName()
- getElementById()
- querySelector()
- querySelectorAll()
Все эти методы являются свойствами объекта. Поэтому, чтобы использовать его, мы должны добавить к этим элементам префикс объекта документа:
document.getElementsByTagName()
document.getElementsByClassName()
document.getElementById()
document.querySelector()
document.querySelectorAll()
Прежде чем мы начнем с этими селекторами, давайте сначала рассмотрим образец HTML-документа, чтобы все эти операции выбора можно было выполнить с помощью этой страницы.
Объектная модель документа
Селекторы DOM
- getElementsByTagName
- getElementsByClassName
- getElementById
- querySelector
- querySelectorAll
Приведенный выше HTML-документ не требует пояснений, поскольку он очень прост. И я буду использовать веб-консоль, чтобы лучше объяснять вещи. Давайте начнем.
getElementsByTagName
Этот метод возвращает все элементы, соответствующие указанным Имя тега .
getElementsByTagName Пример-
document.getElementsByTagName('h2')
возвращает набор элементов, соответствующих имени тега h2 . А так как мы получили только один элемент h2 , то список содержит только один элемент. - Используя [0] в качестве индекса, мы можем получить доступ к первому элементу в списке, который является
.DOM Selectors
-
document.getElementsByTagName('li')
возвращает список из 5 элементов, так как у нас есть пять li Теги на нашей странице. - Любой отдельный элемент можно выбрать, используя его индекс, например
document.getElementsByTagName('li')[0]
.
getElementsByClassName
Этот метод возвращает все элементы, соответствующие указанному имени класса .
getElementsByClassName Пример- Этот селектор очень похож на
getElementsByTagName
, за исключением того, что выбор s основан на имени класса, а не имени тега . Вы можете увидеть несколько примеров на изображении выше.
getElementById
Здесь выбор основан на имени идентификатора . И это похоже на селектор имени тега и имени класса, но есть разница в том, сколько элементов выбирает этот селектор. Во всех приведенных выше селекторах возвращается список всех соответствующих элементов. Но этот селектор возвращает только первый совпадающий элемент, игнорируя остальные .
getElementById Пример- Как видите, несмотря на то, что мы получили 3 элемента li с идентификатором элемента , мы получили только первый элемент li с идентификатором элемента . Остальные все элементы игнорируются.
И вот чем
getElementById
отличается отgetElementsByTagName
иgetElementsByClassName
.getElementById
возвращает элемент, как только он получает совпадение. Также вы можете заметить разницу в названии селектора, слово 9Элемент 0008 стоит в единственном числе вgetElementById
, а во множественном числе в других селекторахgetElementsByTagName
иgetElementsByClassName
.
querySelector
Этот возвращает первый элемент , который соответствует указанному селектору CSS в документе.
querySelector Пример-
document.querySelector('li')
возвращает первый элемент, соответствующий селектору CSSli
. Остальные элементы игнорируются. -
document.querySelector('.heading')
возвращает первый элемент, соответствующий селектору CSS.heading
. -
document.querySelector('#item')
возвращает первый элемент, соответствующий селектору CSS#heading
. - Как видите, мы можем использовать все виды селекторов CSS в методе
querySelector
, который мы будем использовать в обычном файле CSS.
Обратите внимание, что в качестве параметра необходимо использовать селекторы CSS, а не обычные селекторы HTML.
document.querySelector('.className')
действителен, аdocument.querySelector('className')
недействителен. Таким образом, вы должны использовать формат, используемый в селекторах CSS.
querySelectorAll
Этот метод возвращает все элементы, которые соответствуют указанному селектору CSS в документе.
querySelectorAll Пример-
document.querySelectorAll('.heading')
возвращает список всех элементов, соответствующих указанному селектору CSS. Так как у нас есть только один элемент под именем класса.заголовок
список содержит один элемент. И к нему можно получить доступ по его индексу. - Аналогично,
document.querySelectorAll('#item')
возвращает список из 3 элементов, соответствующих селектору CSS.