JavaScript开关中的幻灯片动画不一致

时间:2018-09-06 15:26:37

标签: javascript jquery animation slider carousel

我正在尝试在JavaScript switch语句内实现左右滑动动画,并且该动画(左右滑动没有反弹效果,并且图像之间没有空格)不能持续激活。此外,在第一个幻灯片上单击上一个按钮时,在最后一个幻灯片上单击下一个按钮时,幻灯片动画仍会激活。这不应该发生。有人有想法吗?请参见代码示例。

$(function() {
	// USER EDITABLE CONTROLS
	var content = 'img'; // accepts any DOM element - div, img, table, etc...
	var showControls = true; // true/false shows/hides the slider's navigational controls
	var transition = 'slide'; // supports default, fade, slide
	var transitionDuration = .5; // adjust the time of the transition measured in seconds
	
	// VARIABLE DECLARATIONS
	var contentType = $(content);
	var $el = $('#showcase');
	var $leftArrow = '#left_arrow';
	var $rightArrow = '#right_arrow';
	var $load = $el.find(contentType)[0];
	var slideCount = $el.children().length;
	var slideNum = 1;
	
	// PRELOADS SLIDE WITH CORRECT SETTINGS
	$load.className = 'active';
	
	// ADD SLIDER CONTROLS TO PAGE
	if (showControls === true) {
		$('<div id="controls"><a href="#" id="' + $leftArrow.replace('#', '') + '">&laquo; Previous</a> <a href="#" id="' + $rightArrow.replace('#', '') + '">Next &raquo;</a></div>').insertAfter('#showcase');
		$('#controls').find('#left_arrow').addClass('disabled');
	}
	
	// LOGIC FOR SLIDE TRANSITIONS
	function transitions() {
		switch (transition) {
			// FADE TRANSITION
			case 'fade':
				$('.slide').stop().animate({opacity : 0}, transitionDuration*300, function(){
					$('.active').stop().animate({opacity : 1}, transitionDuration*1000);
				});
				break;

			// SLIDE TRANSITION
			case 'slide':
				if (slideNum > 1) {
					$('.slide').stop().animate({left : -160}, transitionDuration*800, function(){
						$('.active').stop().animate({left : 0}, transitionDuration*1000);
					});
				}
				
				if (slideNum < slideCount) {
					$('.slide').stop().animate({left : 160}, transitionDuration*800, function(){
						$('.active').stop().animate({left : 0}, transitionDuration*1000);
					});
				}
				break;

			// DEFAULT TRANSITION
			case 'default':
				break;
		}
	}
	
	// CHECKS FOR FIRST AND LAST INDEX IN THE SLIDER
	function checkSlide() {
		if (slideNum == 1) {
			$($leftArrow).addClass('disabled');
		} else {
			$($leftArrow).removeClass('disabled');
		}
		
		if (slideNum == slideCount) {
			$($rightArrow).addClass('disabled');
		} else {
			$($rightArrow).removeClass('disabled');
		}
	}

	// NAVIGATIONAL LOGIC FOR PREVIOUS/NEXT BUTTONS
	$(document).on('click', $leftArrow, function() {
		if (slideNum > 1) {
			var counter = $('.active').index();
      counter--;
			$('.active').addClass('slide');
			$('.active').removeClass('active');
			transitions();
			$el.find(contentType).eq(counter).addClass('active');
			slideNum--;
			checkSlide();
		}
	})
	
	$(document).on('click', $rightArrow, function() {
		if (slideNum < slideCount) {
			var counter = $('.active').index();
      counter++;
			$('.active').addClass('slide');
			$('.active').removeClass('active');
			transitions();
			$el.find(contentType).eq(counter).addClass('active');
			slideNum++;
			checkSlide();
		}
	})
});
#showcase {
	width: 160px;
	overflow: hidden;
}

img {
	width: 160px;
}

a {
	color: blue;
}

.disabled {
	color: red !important;
}

.slide {
	display: none;
	opacity: 0;
	position: relative;
	left: 0px;
	right: 0px;
}

.active {
	display: block;
	opacity: 1;
	position: relative;
	left: 0px;
	right: 0px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="showcase">
	<img class="slide" src="https://picsum.photos/458/354" />
	<img class="slide" src="https://picsum.photos/458/354/?image=306" />
	<img class="slide" src="https://picsum.photos/458/354/?image=626" />
</div>

1 个答案:

答案 0 :(得分:0)

如评论中所述,您需要修正条件语句。不久前,您设置了两个click处理程序-当另一个处理程序被触发时,其中一个被绑定(无论任何条件都被触发),这导致单击上一个按钮时幻灯片动画仍会激活在第一张幻灯片上,以及在最后一张幻灯片上单击下一步按钮时问题。

至于动画,请参见下面的代码。我乱砍了你的条件。单击“ previous”时,幻灯片将从左移到右。单击下一步时,幻灯片将从右移到左。我使用了一个标志来确定它将进行的运动-参见过渡函数的新参数

$(function() {
  // USER EDITABLE CONTROLS
  var content = 'img'; // accepts any DOM element - div, img, table, etc...
  var showControls = true; // true/false shows/hides the slider's navigational controls
  var transition = 'slide'; // supports default, fade, slide
  var transitionDuration = .5; // adjust the time of the transition measured in seconds

  // VARIABLE DECLARATIONS
  var contentType = $(content);
  var $el = $('#showcase');
  var $leftArrow = '#left_arrow';
  var $rightArrow = '#right_arrow';
  var $load = $el.find(contentType)[0];
  var slideCount = $el.children().length;
  var slideNum = 1;

  // PRELOADS SLIDE WITH CORRECT SETTINGS
  $load.className = 'active';

  // ADD SLIDER CONTROLS TO PAGE
  if (showControls === true) {
    $('<div id="controls"><a href="#" id="' + $leftArrow.replace('#', '') + '">&laquo; Previous</a> <a href="#" id="' + $rightArrow.replace('#', '') + '">Next &raquo;</a></div>').insertAfter('#showcase');
    $('#controls').find('#left_arrow').addClass('disabled');
  }

  // LOGIC FOR SLIDE TRANSITIONS
  function transitions(impl = null) {
    switch (transition) {
      // FADE TRANSITION
      case 'fade':
        $('.slide').stop().animate({
          opacity: 0
        }, transitionDuration * 300, function() {
          $('.active').stop().animate({
            opacity: 1
          }, transitionDuration * 1000);
        });
        break;

        // SLIDE TRANSITION
      case 'slide':
        if (impl == "next") {
          $('.slide').css("left", '160px');
          $('.slide').stop().animate({
            left: 160
          }, transitionDuration * 800, function() {
            $('.active').stop().animate({
              left: 0
            }, transitionDuration * 1000);
          });
        } else if (impl == "prev") {
          $('.slide').css("left", '-160px');
          $('.slide').stop().animate({
            left: -160
          }, transitionDuration * 800, function() {
            $('.active').stop().animate({
              left: 0
            }, transitionDuration * 1000);
          });
        }
        break;

        // DEFAULT TRANSITION
      case 'default':
        break;
    }
  }

  // CHECKS FOR FIRST AND LAST INDEX IN THE SLIDER
  function checkSlide() {
    if (slideNum == 1) {
      $($leftArrow).addClass('disabled');
    } else {
      $($leftArrow).removeClass('disabled');
    }

    if (slideNum == slideCount) {
      $($rightArrow).addClass('disabled');
    } else {
      $($rightArrow).removeClass('disabled');
    }
  }

  // NAVIGATIONAL LOGIC FOR PREVIOUS/NEXT BUTTONS
  $(document).on('click', $leftArrow, function() {
    if (slideNum > 1) {
      var counter = $('.active').index();
      counter--;
      $('.active').addClass('slide');
      $('.active').removeClass('active');
      transitions('prev');
      $el.find(contentType).eq(counter).addClass('active');
      slideNum--;
      checkSlide();
    }
  })

  $(document).on('click', $rightArrow, function() {
    if (slideNum < slideCount) {
      var counter = $('.active').index();
      counter++;
      $('.active').addClass('slide');
      $('.active').removeClass('active');
      transitions('next');
      $el.find(contentType).eq(counter).addClass('active');
      slideNum++;
      checkSlide();
    }
  })
});
#showcase {
  width: 160px;
  overflow: hidden;
}

img {
  width: 160px;
}

a {
  color: blue;
}

.disabled {
  color: red !important;
}

.slide {
  display: none;
  opacity: 0;
  position: relative;
  left: 0px;
  right: 0px;
}

.active {
  display: block;
  opacity: 1;
  position: relative;
  left: 0px;
  right: 0px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="showcase">
  <img class="slide" src="https://picsum.photos/458/354" />
  <img class="slide" style="left: 160px;" src="https://picsum.photos/458/354/?image=306" />
  <img class="slide" style="left: 160px;" src="https://picsum.photos/458/354/?image=626" />
</div>