@gotohell

Автоматическая прокрутка слайдера?

Всем привет у меня есть слайдер, все работает вот только я не могу настроить его на автоматическую прокрутку
$(document).ready(function() {
 $(".slider").each(function () { // обрабатываем каждый слайдер
  var obj = $(this);
  $(obj).append("<div class='nav'></div>");
  $(obj).find("li").each(function () {
   $(obj).find(".nav").append("<span rel='"+$(this).index()+"'></span>"); // добавляем блок навигации
   $(this).addClass("slider"+$(this).index());
  });
  $(obj).find("span").first().addClass("on"); // делаем активным первый элемент меню
 });
});
function sliderJS (obj, sl) { // slider function
 var ul = $(sl).find("ul"); // находим блок
 var bl = $(sl).find("li.slider"+obj); // находим любой из элементов блока
 var step = $(bl).width(); // ширина объекта
 $(ul).animate({marginLeft: "-"+step*obj}, 500); // 500 это скорость перемотки
}
$(document).on("click", ".slider .nav span", function() { // slider click navigate
 var sl = $(this).closest(".slider"); // находим, в каком блоке был клик
 $(sl).find("span").removeClass("on"); // убираем активный элемент
 $(this).addClass("on"); // делаем активным текущий
 var obj = $(this).attr("rel"); // узнаем его номер
 sliderJS(obj, sl); // слайдим
 return false;
});


https://codepen.io/webmasterotboga/pen/awwOZK - ссылка на кодпен
  • Вопрос задан
  • 1577 просмотров
Решения вопроса 1
function autoplay() {
  var active    = $('.slider .nav span.on'),
      index     = parseInt(active.attr('rel')),
      maxIndex  = $('.slider .nav span').length - 1,
      nextIndex = index+1;

  if ( nextIndex > maxIndex ) nextIndex = 0;

  $('.slider .nav span[rel="'+nextIndex+'"]').click();
}


вот пример - https://codepen.io/anon/pen/RggWNR

И мой вам совет, сделайте рефакторинг кода.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
22 нояб. 2024, в 23:55
3000 руб./за проект
22 нояб. 2024, в 22:26
3500 руб./за проект
22 нояб. 2024, в 21:47
3000 руб./за проект