Не можете передать HTML Collection в качестве параметра в функцию Js?
Я изучал слайд-шоу на w3schools, чтобы научиться создавать свои собственные.
Это ссылка на код урока. Однако я имею в виду этот код.
<script>
var slideIndex = 0;
showSlides();
function showSlides() {
var i;
var slides =
document.getElementsByClassName("mySlides");
var dots = document.getElementsByClassName("dot");
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
slideIndex++;
if (slideIndex > slides.length) {slideIndex = 1}
for (i = 0; i < dots.length; i++) {
dots[i].className = dots[i].className.replace("
active", "");
}
slides[slideIndex-1].style.display = "block";
dots[slideIndex-1].className += " active";
setTimeout(showSlides, 2000); // Change image every
2 seconds
}
</script>
Я хотел сделать несколько слайд-шоу для одной страницы, поэтому я сделал так, чтобы этот раздел кода принимал параметр, а затем я мог просто вставить свой список изображений. Но когда я изменил код на это...
var images = document.getElementsByClassName("mySlides");
var imageNum = document.getElementsByClassName("dot");
showSlides(images, imageNum);
function showSlides(slides, dots) {
var i;
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
slideIndex++;
if (slideIndex > slides.length) {slideIndex = 1}
for (i = 0; i < dots.length; i++) {
dots[i].className = dots[i].className.replace(" active", "");
}
slides[slideIndex-1].style.display = "block";
dots[slideIndex-1].className += " active";
setTimeout(showSlides, 2000);
}
Полный код доступен по этой ссылке.
Это дает мне свойство error длины undefined, хотя.length можно использовать в HTML-коллекции.
Почему кажется, что эта функция не может принимать HTML-коллекцию в качестве параметра?
Изменить: просмотрев отзывы и заметив, что людям стало труднее помогать мне, я сделал ссылку на коды и ящики со своей проблемой. Я включил решение в качестве комментария, чтобы люди могли видеть до и после. Я также включил всю функцию выше.
Спасибо за ваш отзыв, чтобы я мог сделать вопросы более ясными и извините за проблемы!
1 ответ
Это из-за этой строки в конце функции
setTimeout(showSlides, 2000); // Change image every 2 seconds
это вызов showSlides
без каких-либо аргументов
Чтобы добавить аргумент для вызова, вы можете сделать:
setTimeout(() => { showSlides(slides, dots) }, 2000);
// call from an anonymous function
// or
setTimeout(showSlides, 2000, slides, dots);
// use additional params of setTimeout
Вот документ для setTimeout