Я написал пользовательский слайдер с объектно-ориентированным javascript, как показано ниже. Я включил модуль в скрипку здесь https://jsfiddle.net/5z29xhzg/7/. После скольжения влево или вправо слайды клонируются и присоединяются соответственно так, чтобы пользователь мог перемещаться по ползунку столько, сколько захотелось. Для управления активной вкладкой существует отдельная функция. При использовании отдельно, вкладки и слайдер работают отлично, но у меня возникает проблема, когда они используются в объединении. Например, щелкнув «синий фартук», а затем нажав левую кнопку слайда (который приведет вас к слайду «dave &»), вы попадете на сладостный слайд. Или щелкнув последний слайд с помощью вкладок, а затем нажав следующую кнопку, ничего не отображается. Может кто-то указать на недостаток в объекте, который я написал. Любая помощь высоко ценится!Пользовательский слайдер проблема
GiftSlider = {
prev: '.slider-container .prev',
next: '.slider-container .next',
slide: '.slide',
slidesContainer: '#slides',
navLink: '.gift-nav li a',
init: function() {
// Initialize nextSlide function when clicking right arrow
$(this.next).click(this.nextSlide.bind(this));
$(this.next).click(this.activeTabs.bind(this));
// Initialize prevSlide function when clicking left arrow
$(this.prev).click(this.prevSlide.bind(this));
$(this.prev).click(this.activeTabs.bind(this));
// Initialize toggleSlides and activeTab functions when clicking nav links
$(this.navLink).click(this.toggleSlides.bind(this));
$(this.navLink).click(this.activeTabs.bind(this));
},
nextSlide: function(e) {
// Prevent default anchor click
e.preventDefault();
// Set the current slide
var currentSlide = $('.slide.current');
// Set the next slide
var nextSlide = $('.slide.current').next();
// remove the current class from the current slide
currentSlide.removeClass("current");
// Move the current slide to the end so we can cycle through
currentSlide.clone().appendTo(this.slidesContainer);
// remove the last slide so there is not two instances
currentSlide.remove();
// Add current class to next slide to display it
nextSlide.addClass("current");
},
prevSlide: function(e) {
// Prevent defaulct anchor click
e.preventDefault();
// Set the current slide
var currentSlide = $('.slide.current');
// Set the last slide
var lastSlide = $('.slide').last();
// remove the current class from the current slide
currentSlide.removeClass("current");
// Move the last slide to the beginning so we can cycle through
lastSlide.clone().prependTo(this.slidesContainer);
// remove the last slide so there is not two instances
lastSlide.remove();
// Add current class to new first slide
$('.slide').first().addClass("current");
},
toggleSlides: function(e) {
// Prevent defaulct anchor click
e.preventDefault();
var itemData = e.currentTarget.dataset.index;
var currentSlide = $('.slide.current');
currentSlide.removeClass("current");
newSlide = $('#slide-' + itemData);
// currentSlide.clone().appendTo(this.slidesContainer);
newSlide.addClass("current");
// console.log(newSlide);
},
activeTabs: function() {
// *** This could be much simpler if we didnt need to match the slider buttons
// *** up with nav tabs. Because I need to track the slider as well, I have
// *** made this its own function to be used in both instances
// get the active slide
var activeSlide = $('.slide').filter(':visible');
// get the active slide's id
var currentId = activeSlide.attr('id');
// grab just the number from the active slide's id
var currentNum = currentId.slice(-1);
// remove any active gift-nav links
$(this.navLink).removeClass("active");
// get the current tab by matching it to the current slide's id
var currentTab = $('.gift-nav li a[data-index="' + currentNum + '"]');
// make that active
currentTab.addClass("active");
}
}
$(document).ready(function(){
// Init our objects
GiftSlider.init();
});
скрипку не что ясно, поскольку пара изображений отсутствует? И есть разные фото, но только 2 ссылки когда-либо появляются наверху. Из моего использования все равно ... Не могли бы вы обновить ссылки и, возможно, добавить комментарий re. ожидаемое поведение? –
@RachelGallen Да, извините за это. Я сделаю это более ясным. – JordanBarber
@RachelGallen. Изображения в слайдере - все внешние источники, поэтому вы должны увидеть их все. Я удалил ненужные «логотипы» изображений в этом https://jsfiddle.net/5z29xhzg/7/. Есть четыре навигационных ссылки, поэтому я не знаю, почему вы только видите два. – JordanBarber