Я только учу JS, поэтому если допустил какую-то элементарную ошибку, которая привела к проблеме, то заранее извините. В общем, у меня есть следующая переменная:
let deleteIcons = document.getElementsByClassName('material-icons');
В ней собраны иконки удаления элемента списка, который я генерирую. Цель - реализовать удаление элемента при клике на иконку. Для того, чтобы повесить обработчик событий и отслеживать клик по каждой иконке, мне нужно сначала перебрать коллекцию, чтобы на каждой итерации добавлять событие. Ну а теперь мы подошли к сути проблемы:
for (let i = 0; i < deleteIcons.length; i++) {
console.log(deleteIcons[i]);
};
при моей попытке перебрать массив ничего не происходит (консольлогом я просто проверяю работоспособность кода). Вообще ничего, ни ошибки, ни ворнинга, по мнению редактора с консолью девтулс всё нормально. Когда я пытаюсь перебрать что-то другое, то никаких проблем.
let array = [1, 2, 3, 4, 5, 6, 7];
for (let i = 0; i < array.length; i++) {
console.log(array[i]);
};
Заранее спасибо за ответы и извините, если проблема тривиальная, а решение очевидно.
getElementsByClassName
возвращает живую коллекцию, то есть любое изменение в DOM, сразу отображается в коллекции.
Это значит, что получив коллекцию до того как добавились элементы, после их добавления - в коллекции все равно будут актуальные данные, но перебор коллекции до и после добавления элементов будет отличаться:
var tests = document.getElementsByClassName('test');
console.log('tests.length:', tests.length);
tests[0].className = 'without-test';
console.log('tests.length:', tests.length);
#container div::after {
content: attr(class);
}
#container div {
border: 1px solid red;
}
#container .test {
border: 1px solid green;
}
<div id="container">
<div class="test"></div>
<div class="test"></div>
<div class="test"></div>
<div class="test"></div>
<div class="test"></div>
</div>
Айфон мало держит заряд, разбираемся с проблемой вместе с AppLab
Перевод документов на английский язык: Важность и ключевые аспекты
Какие существуют виды рекламных бордов и как выбрать подходящий?
У меня есть набор data-uri и ссылок, по которым я могу послать ajax-запросы, а также немного дополнительной текстовой информацииПри этом скрипт...
До сих пор не приходилось что-то делать с таблицами БД, не зная их имёнИ теперь возникла необходимость занести в массив имена большого числа...