Задать вопрос
@corona-net

Почему перестаёт срабатывать скрипт?

Есть сайт u0763918test1.isp.regruhosting.ru
В нём отображается список картинок, при клике на каждую отображаются адресс картинки и она же в большем виде в контейнере.
Также есть возможность закачать свою картинку отдельно. Но здесь перестаёт срабатывать скрипт, он передаёт адресс картинки, но перестаёт отображать картинку.

Вот сам скрипт:

<script>
    function countRabbits() {
        let pictures = document.querySelectorAll(".picture");
        let boxTwo = document.querySelector(".box2");
        let boxText = document.querySelector(".boxText99");

        pictures.forEach((picture) => {

            let background = picture.getAttribute("src");

            picture.addEventListener("click", (e) => {
                boxTwo.style.background = `url(${background}) no-repeat center/cover`;
                boxText.innerText = background;
            });

        });
    }

</script>
  • Вопрос задан
  • 89 просмотров
Подписаться 2 Средний Комментировать
Пригласить эксперта
Ответы на вопрос 1
@Onzabr
Это происходит из-за того, что вы добавляете элементы динамически. Попробуйте повесить обработчик на document, затем добавьте проверку на наличие класса элемента.

document.addEventListener('click', event => {
	let picture = event.target;
	let boxTwo = document.querySelector(".box2");
	let boxText = document.querySelector(".boxText99");
	
	if (picture.classList.contains('picture')) { // проверяем, действительно ли это элемент с классом picture
		let background = picture.getAttribute("src");
		boxTwo.style.background = `url(${background}) no-repeat center/cover`;
		boxText.innerText = background;
	}
});
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 12:39
1000 руб./за проект
18 дек. 2024, в 12:37
10000 руб./за проект
18 дек. 2024, в 12:22
5000 руб./за проект