H
H
Hastes12342020-04-26 20:20:16
JavaScript
Hastes1234, 2020-04-26 20:20:16

How to implement an event listener on an array?

Hello. Using native JS, I want to implement a simple slider.
I wanted to know how you can make it so that there are 4 elements on the screen, and the rest are hidden using a class, so that all elements scroll in turn. In general, the usual simple slider. Thank you!

const nextArr = document.querySelector(".slider__arrow_next");
      const prevArr = document.querySelector(".slider__arrow_prev");
      const arrSlides = document.getElementsByClassName("slider__slide");

      for (let index = 0; index < arrSlides.length; index++) {
        prevArr.addEventListener("click", () => {
          arrSlides[index].classList.toggle("slider__slide_hide");
        });
        console.log(index);
        
      }

      for (let index = 0; index < arrSlides.length; index++) {
        nextArr.addEventListener("click", () => {
          arrSlides[index].classList.toggle("slider__slide_hide");
        });
      }

Answer the question

In order to leave comments, you need to log in

1 answer(s)
A
Arseny, 2020-04-26
Matytsyn @ArsenyMatytsyn

You came from the wrong side.
You need to get an array of elements, and drive elements back and forth in its range (or transfer elements from end to beginning and vice versa for an infinite loop) elements.
And in order to show several elements, you should, by clicking on the arrow, increment (for example) the index of the active element and from it it is passed in the n-range (given or calculated) through the elements to which you will add the active display class.
It sounds complicated in the way that you are doing, and no one in their right mind will write code for you, because there are a lot of slider implementations in native JS and, moreover, in html + css (without JS) on the Internet.

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question