@Aziret

Как сделать анимацию на JavaScript (setInterval())?

Не могу реализовать анимацию слайдера. При клике на кнопку должна плавна меняться картинки, с использованием setInterval().

<!DOCTYPE html>

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title></title>
    <meta name="description" content="">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="./styles/main.css">
</head>

<body>

    <div class="slider">

        <div class="item">
            <img src="img/1.jpg" alt="Первый слайд">
        </div>

        <div class="item">
            <img src="img/2.jpg" alt="Второй слайд">
        </div>

        <div class="item">
            <img src="img/3.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/4.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/5.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/6.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/7.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/8.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/9.jpg" alt="Третий слайд">
        </div>

        <div class="item">
            <img src="img/10.jpg" alt="Третий слайд">
        </div>

        <a class="prev" onclick="minusSlide()">&#10094;</a>
        <a class="next" onclick="plusSlide()">&#10095;</a>

    </div>

    <div class="slider-dots">
        <span class="slider-dots_item" onclick="currentSlide(1)"></span>
        <span class="slider-dots_item" onclick="currentSlide(2)"></span>
        <span class="slider-dots_item" onclick="currentSlide(3)"></span>
        <span class="slider-dots_item" onclick="currentSlide(4)"></span>
        <span class="slider-dots_item" onclick="currentSlide(5)"></span>
        <span class="slider-dots_item" onclick="currentSlide(6)"></span>
        <span class="slider-dots_item" onclick="currentSlide(7)"></span>
        <span class="slider-dots_item" onclick="currentSlide(8)"></span>
        <span class="slider-dots_item" onclick="currentSlide(9)"></span>
        <span class="slider-dots_item" onclick="currentSlide(10)"></span>

    </div>


    <script>
        /* Индекс слайда по умолчанию */
        var slideIndex = 1;
        showSlides(slideIndex);

        /* Функция увеличивает индекс на 1, показывает следующй слайд*/
        function plusSlide() {
            showSlides(slideIndex += 1);
        }

        /* Функция уменьшяет индекс на 1, показывает предыдущий слайд*/
        function minusSlide() {
            showSlides(slideIndex -= 1);
        }

        /* Устанавливает текущий слайд */
        function currentSlide(n) {
            showSlides(slideIndex = n);
        }

        /* Основная функция слайдера */
        function showSlides(n) {
            var i;
            var slides = document.getElementsByClassName("item");
            var dots = document.getElementsByClassName("slider-dots_item");
            if (n > slides.length) {
                slideIndex = 1
            }
            if (n < 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", "");
            }
            slides[slideIndex - 1].style.display = "block";
            dots[slideIndex - 1].className += " active";
        }

        var timer = setInterval(function() {

            if (plusSlide()) train.style.left = +'px';
            else train.style.left = -'px';

            if (timePassed > 2000) {
                clearInterval(timer);
            }
        }, 3000);
    </script>

</body>

</html>
  • Вопрос задан
  • 429 просмотров
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы