Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
23 / 7 / 0
Регистрация: 24.04.2018
Сообщений: 411

Поиск по querySelector

23.09.2021, 17:35. Показов 1364. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Чем отличается обращение через body и querySelector('body')
Какой способ лучше использовать 1 или 2 ?


JavaScript
1
2
let a = document.querySelector('body').style.display ="none";  // 1 способ
let b = document.body.style.display ="none";                   // 2 способ
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.09.2021, 17:35
Ответы с готовыми решениями:

GetElement, querySelector
Есть такой код .... в нем присваивается первой строке цвет, второй строке слово "www", это все вручную прописано какой строке что...

E.outerHTML.querySelector возвращает строку
e.outerHTML.querySelector('#404') Как строчку возвращает

Узнать существует ли селектор querySelector
Подскажите как узнать существует ли <span class="nameclass">...</span> в блоке, и если нет, то вывести сообщение или скрыть блок, блоки...

8
1 / 1 / 0
Регистрация: 27.08.2014
Сообщений: 29
23.09.2021, 18:33
Полагаю что через querySelector ф-я будет искать элементы пока не дойдет до body, а через прямое обращение идет сразу туда куда нужно. Наверное разницы особо нет, но это не точно, почитайте о том как работает querySelector
0
 Аватар для klyapa
3503 / 1267 / 429
Регистрация: 24.07.2016
Сообщений: 1,890
23.09.2021, 18:45
Цитата Сообщение от Kerduk Посмотреть сообщение
Какой способ лучше использовать 1 или 2 ?
В первом способе идёт обращение к методу объекта document, который тратит время на поиск элемента body, а во втором, обращение напрямую к свойству body объекта document. Второй способ более "быстрый". Можете сами посмотреть время в консоли бровзера:

JavaScript
1
2
3
4
5
6
7
console.time("querySelector");
let a = document.querySelector('body').style.display ="none"; // 1 способ
console.timeEnd("querySelector");
 
console.time("document.body");
let b = document.body.style.display ="none"; // 2 способ
console.timeEnd("document.body");
1
23 / 7 / 0
Регистрация: 24.04.2018
Сообщений: 411
23.09.2021, 19:39  [ТС]
В первом способе идёт обращение к методу объекта document, который тратит время на поиск элемента body, а во втором, обращение напрямую к свойству body объекта document. Второй способ более "быстрый". Можете сами посмотреть время в консоли бровзера:
klyapa, а второй способ разве это не глобальное обращение к элементу?
Просто мне сказали на форуме, что глобальное обращение лучше не использовать.
0
супермизантроп
Эксперт JS
3941 / 2979 / 692
Регистрация: 18.04.2012
Сообщений: 8,629
23.09.2021, 20:46
Цитата Сообщение от Kerduk Посмотреть сообщение
Просто мне сказали на форуме, что глобальное обращение лучше не использовать.
а вы всегда всех дураков слушаетесь, как это вам еще никто не посоветовал выпрыгнуть из окна?

на странице может быть любое количество любых тегов, за исключением тегов <!doctype>, <head>, <title> и <body> --они должны быть в единственном экземпляре, и именно поэтому только к ним можно и нужно обращаться напрямую
2
23 / 7 / 0
Регистрация: 24.04.2018
Сообщений: 411
24.09.2021, 01:59  [ТС]
kalabuni, так мне говорили опытные разрабы с большим стажем,
что у профессионалов за глобальное обращение убивают на месте без суда и следствия.
Напрямую - вы имеете в виду глобальное обращение?
Я так и не могу понять, как выглядит глобальное обращение.
Пожалуйста, приведите мне пример этого самого глобального обращение к элементу.
0
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
24.09.2021, 05:33
Лучший ответ Сообщение было отмечено amr-now как решение

Решение

Цитата Сообщение от Kerduk Посмотреть сообщение
Пожалуйста, приведите мне пример этого самого глобального обращение к элементу.
Вот это что:
Обычно в литературе для доступа к элементу рекомендуют использовать document.getElementById("id_").
Например, изменить ширину элемента:
HTML5
1
<div id=scroller><div>
Я пишу:
JavaScript
1
document.getElementById("scroller").width = "100px";
Но часто встречаю исходники, где к элементу обращаются по id непосредственно так:
JavaScript
1
scroller.width = "100px";
Насколько это правильно и допустимо?
Это не правильно и не допустимо.
Надо всегда писать:
JavaScript
1
2
let scroller = document.getElementById("scroller");
scroller.width = "100px";
или заведомо при однократном обращении к элементу:
JavaScript
1
document.getElementById("scroller").width = "100px";
Иначе будет конфликт распознавания объявленных и необъявленных переменных. Нужно, чтобы все переменные были объявленными.
0
23 / 7 / 0
Регистрация: 24.04.2018
Сообщений: 411
24.09.2021, 10:14  [ТС]
amr-now, спасибо большое!
А глобальное обращение к элементу бывает только по id?
0
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
24.09.2021, 10:20
Kerduk, наверно.

Кстати, обращение к document.body, document.forms, document.images и т.д. вполне нормально.
Никакой путаницы с переменными не будет. Это штатные свойства объекта document.

-------
Можете посмотреть лично все свойства объекта document:
JavaScript
1
console.dir(document);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.09.2021, 10:20
Помогаю со студенческими работами здесь

FF 49.0.2 vs. document.querySelector
Под FF 49.0.2 не работает document.querySelector и не пойму в чём дело Была такая строчка document.querySelector('thead').innerHTML ...

QuerySelector (querySelectorAll)
итак, суть: есть такая функция querySelector, которая позволяет получить элементы HTML по в принципе любому признаку, будь то класс, id,...

Xml doc querySelector
xmlDoc = new DOMParser().parseFromString('&lt;a href=&quot;test&quot; class=&quot;mailreg&quot;&gt;&lt;/a&gt;', 'text/xml'); var hreftest =...

Как получить дочерние элементы через querySelector?
Допустим у меня есть переменная elem, содержащая ссылку на произвольный DOM-элемент. Можно ли через elem.querySelector получить...

Выполнить поиск, указанного пользователем элемента, двумя методами: применив последовательный поиск и бинарный поиск
написать программу в паскале 4) Любым способом задать отсортированный массив. Выполнить поиск, указанного пользователем элемента,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru