I have this line of code from each function of my carousel interface: dots[(i+len-1)%len].className = dots[(i+len-1)%len].className.replace(" active", "")
It removes the previous class "active" on every iteration of dot elements. If i do not add this code on each function, class "active" propagates by more than one on each iteration like this: <span class="dot active active active active" onclick="dotSlide(1)"></span>
It's a bug, during the slide of the carousel or when i press next or prev button the active dot is not align with the image by its corresponding index. How can i reduce this codes.
var slideIndex = 0;
loop();
var slides, dots;
function loop() {
slides = document.getElementsByClassName("slides");
dots = document.getElementsByClassName("dot");
for (var i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
slideIndex++;
var len = dots.length;
if (slideIndex > slides.length) {
slideIndex = 1
}
for (var i = 0; i < dots.length; i++) {
dots[i].className = dots[i].className.replace(" active", "");
dots[(i + len - 1) % len].className = dots[(i + len - 1) % len].className.replace(" active", "")
dots[(i + len - 2) % len].className = dots[(i + len - 2) % len].className.replace(" active", "");
dots[(i + len - 3) % len].className = dots[(i + len - 3) % len].className.replace(" active", "")
}
slides[slideIndex - 1].style.display = "block";
dots[slideIndex - 1].className += " active";
setTimeout(loop, 6000); // Change image every 6 seconds
}
function plusSlides(position) {
var len = dots.length;
slideIndex += position;
if (slideIndex > slides.length) {
slideIndex = 1
} else if (slideIndex < 1) {
slideIndex = slides.length
}
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
for (i = 0; i < dots.length; i++) {
dots[i].className = dots[i].className.replace(" active", "");
dots[(i + len - 1) % len].className = dots[(i + len - 1) % len].className.replace(" active", "");
dots[(i + len - 2) % len].className = dots[(i + len - 2) % len].className.replace(" active", "")
dots[(i + len - 3) % len].className = dots[(i + len - 3) % len].className.replace(" active", "")
slides[slideIndex - 1].style.display = "block";
dots[slideIndex - 1].className += " active";
}
}
function dotSlide(index) {
if (index > slides.length) {
index = 1
} else if (index < 1) {
index = slides.length
}
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
var len = dots.length;
for (i = 0; i < dots.length; i++) {
dots[i].className = dots[i].className.replace(" active", "");
dots[(i + len - 1) % len].className = dots[(i + len - 1) % len].className.replace(" active", "");
dots[(i + len - 2) % len].className = dots[(i + len - 2) % len].className.replace(" active", "")
dots[(i + len - 3) % len].className = dots[(i + len - 3) % len].className.replace(" active", "")
slides[index - 1].style.display = "block";
dots[index - 1].className += " active";
}
}
<div id="slide">
<div class="slides-container" style="text-align:center">
<div class="slides fadeOut"> <img src="images/pine_forest.jpg"> </div>
<div class="slides fadeOut"> <img src="images/best-forest.jpg"> </div>
<div class="slides fadeOut"> <img src="images/EarthBeauty221.jpg"> </div>
<div class="slides fadeOut"> <img src="images/setwalls.ru-79192.jpg"> </div>
<a class="prev" onclick="plusSlides(-1)">❮</a>
<a class="next" onclick="plusSlides(1)">❯</a>
</div>
</div>
<div class="dots" style="text-align:center">
<span class="dot" onclick="dotSlide(1)"></span>
<span class="dot" onclick="dotSlide(2)"></span>
<span class="dot" onclick="dotSlide(3)"></span>
<span class="dot" onclick="dotSlide(4)"></span>
</div>