Выберите теги в родительском классе javascript

Я могу использовать это, чтобы выбрать все теги привязки в документе, что отлично работает ...

var anchors = document.getElementsByTagName('a');

Специально для замены функциональности "href" на "onclick" (для расширения функциональности без использования javascript, добавления миниатюр и т. д.)

За исключением того, как я могу заставить его выбирать только элементы привязки в определенном классе родительского элемента (например, pics), оставив только большую часть привязок?

<a href = "img/TEST/pretty.jpg">ignore me</a>
<div class = "pics">
 <a href = "img/TEST/testPic1.jpg">1 stuff....</a>
 <a href = "img/TEST/testPic2.jpg">2 stuff...</a>
 <a href = "img/TEST/TestPic3.jpg">3 stuff..</a>
 ...
 <a href = "img/TEST/TestPicN.jpg">n stuff..</a>
</div>

... без дополнительные библиотеки, такие как jQuery, пожалуйста!

Вот небольшая демонстрация ...

function go() {
    var anchorElements = document.getElementsByTagName('a');
    for (var i in anchorElements)
        anchorElements[i].style.backgroundColor = "red";
}
a{background-color:#0F0;}
<a href = "img/TEST/pretty.jpg">ignore me</a>
<div class = "pics">
 <a href = "img/TEST/testPic1.jpg">1 stuff....</a>
 <a href = "img/TEST/testPic2.jpg">2 stuff...</a>
 <a href = "img/TEST/TestPic3.jpg">3 stuff..</a>
 ...
 <a href = "img/TEST/TestPicN.jpg">n stuff..</a>
</div>
<button onclick = "go()">Go!</button>

I know a workaround is just to select by a class applied to the elements that need modifying

вы можете легко сделать это с помощью селектора DOM

Chase 03.07.2018 01:28

Не все элементы A являются ссылками, вы можете получить все ссылки с помощью document.links. ;-)

RobG 03.07.2018 01:58
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
2
645
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Используйте querySelectorAll('.pics a'), чтобы выбрать коллекцию <a> в классе .pic

function go() {
    var anchorElements = document.querySelectorAll('.pics a');
    for (var i in anchorElements)
        anchorElements[i].style.backgroundColor = "red";
}
a{background-color:#0F0;}
<a href = "img/TEST/pretty.jpg">ignore me</a>
<div class = "pics">
 <a href = "img/TEST/testPic1.jpg">1 stuff....</a>
 <a href = "img/TEST/testPic2.jpg">2 stuff...</a>
 <a href = "img/TEST/TestPic3.jpg">3 stuff..</a>
 ...
 <a href = "img/TEST/TestPicN.jpg">n stuff..</a>
</div>
<button onclick = "go()">Go!</button>

Ваш ответ будет гораздо полезнее для других, если вы объясните, что вы изменили и почему. Пожалуйста, редактировать свой ответ.

Felix Kling 03.07.2018 01:33

Достаточно для моего уровня xD, спасибо! Похоже, он использует селекторы CSS

Wilf 03.07.2018 01:43

Может быть гораздо эффективнее добавить правило CSS, чем выбирать, а затем перебирать все соответствующие элементы по одному.

RobG 03.07.2018 02:01

Другие вопросы по теме