12

我正在使用 Flexslider,并被要求在不同的时间显示每张幻灯片,具体取决于它有多少内容,对于短句来说如此之快,而对于一个段落来说则慢。当 flexslide 只允许 1 个 Slideshowspeed 值时,我该如何设置。我的代码:

$(window).load(function() {
        $('#flexslider1').flexslider({
        easing: "swing",  
        animation: "fade",
        slideshowSpeed: 7000,
        animationSpeed: 600,
        startAt: 0,
        initDelay: 0,
        controlNav: true,
        directionNav: true,
        pausePlay: true,
        pauseText: 'Pause',
        playText: 'Play'
    }); 
});
4

6 回答 6

10

我在尝试仅将一张幻灯片的速度更改为与其他幻灯片不同时遇到了同样的问题。这是我使用的脚本,它有效!

  <script type="text/javascript">
$(window).load(function(){
  $('.flexslider').flexslider({
    animation: "fade",
    slideshowSpeed: 1500,
    animationSpeed: 1000, 
    controlNav: false, 

    start: function(slider){
      slider.removeClass('loading');
    },
    after: function(slider){
        if(slider.currentSlide == 3){
            slider.pause();
            setTimeout(function(){
                slider.play();
            }, 5000);
        }
    }
  });
});

我总共有 5 张图片,但我希望第 4 张幻灯片(slider.currentSlide == 3)停留更长时间 5 秒。

于 2013-02-15T16:49:13.787 回答
6

我想我找到了解决办法。我使用 after 回调来更改 slideshowSpeed 的间隔:

$(window).load(function(){
      $('.flexslider').flexslider({
        animation: "slide",
        slideshowSpeed: time,
        controlNav: false,
        directionNav: false,
        pauseOnAction: false,
        pauseOnHover: false, 
        pausePlay: true,
        after: function(slider){
            clearInterval(slider.animatedSlides); 
            slider.animatedSlides = setInterval(slider.animateSlides,*YOURTIME in MS*)
        },
        start: function(slider){
          $('body').removeClass('loading');
        }
      }); 
    });

希望能帮助到你!

蒂博。

于 2012-11-15T08:17:43.560 回答
5

意识到这是旧的,但对于其他人来说,就像我一样,你也可以这样做:(使用 FlexSlider v.2.2.2)。

将 data-duration 属性添加到 li 的

<div class="flexslider" data-animation="fade" data-control-nav="false" data-slideshow="true" data-start-at="0">
    <ul class="slides">
        <li data-duration="6000">
            <img src="http://placehold.it/600x210" alt="Alt" />
        </li>
        <li data-duration="2000">
            <img src="http://placehold.it/600x200" alt="Alt Text" />
        </li>
    </ul>
</div>

在您的页面初始化中:

$hook = $('.flexslider');
$hook.flexslider({
                    animation: $hook.data('animation'),
                    controlNav: $hook.data('control-nav'),
                    slideshow: $hook.data('slideshow'),
                    startAt: $hook.data('start-at'),
                    pauseOnHover: true,
                    controlNav: false,
                    after: function(slider){
                        // clears the interval
                        slider.stop();
                        // grab the duration to show this slide
                        slider.vars.slideshowSpeed = $(slider.slides[slider.currentSlide]).data('duration');
                        // start the interval
                        slider.play();
                    }
                });

在这里提琴:

http://jsfiddle.net/uzery/3/

于 2014-06-09T20:56:54.957 回答
1

因为在第一张幻灯片动画之后的回调 CALL 之后,我们需要在 START 回调中添加超时(对于 3 张幻灯片):

  $(window).load(function() {        
    $('.flexslider').flexslider({
        animation: "slide",
        controlNav: false,
        directionNav: false,           
        pausePlay: true,
        animationSpeed: 300,
        start: function(slider) {
            clearInterval(slider.animatedSlides);
            slider.animatedSlides = setInterval(slider.animateSlides, YOUR_TIMEOUT_FOR_FIRST_SLIDE(ONLY FOR START));                
        },
        after: function(slider){
            if(slider.currentSlide == 0) {
               clearInterval(slider.animatedSlides); 
               slider.animatedSlides = setInterval(slider.animateSlides, FIRST_TIMEOUT);
            }
            if(slider.currentSlide == 1) {
               clearInterval(slider.animatedSlides); 
               slider.animatedSlides = setInterval(slider.animateSlides, SECOND_TIMEOUT);
            }
            if(slider.currentSlide == 2) {
               clearInterval(slider.animatedSlides); 
               slider.animatedSlides = setInterval(slider.animateSlides, THIRD_TIMEOUT);
            }
        }          
    });
  });
于 2013-04-07T20:10:15.767 回答
1

结合上面的两个答案

$hook = $('.flexslider');
$hook.flexslider({
    animation: $hook.data('animation'),
    controlNav: $hook.data('control-nav'),
    slideshow: $hook.data('slideshow'),
    startAt: $hook.data('start-at'),
    pauseOnHover: true,
    controlNav: false,
    start: function(slider) {
        var start_time = $(slider.slides[slider.currentSlide]).data('duration');
        clearInterval(slider.animatedSlides);
        slider.animatedSlides = setInterval(slider.animateSlides, start_time);
    },
    after: function(slider){
        // clears the interval
        slider.stop();
        // grab the duration to show this slide
        slider.vars.slideshowSpeed = $(slider.slides[slider.currentSlide]).data('duration');
        // start the interval
        slider.play();
    }
});

于 2017-10-11T15:41:22.060 回答
0

我不知道 flexslider 但你应该能够在事件函数回调之后修改速度。像这样的东西:

$('#flexslider1').flexslider({
easing: "swing",  
animation: "fade",
slideshowSpeed: 7000,
animationSpeed: 600,
startAt: 0, 
initDelay: 0,
controlNav: true,              
directionNav: true,
pausePlay: true,
pauseText: 'Pause',            
playText: 'Play',
after: function(){$(this).flexslider('slideshowSpeed',1000)} 
}); 

但是现在,你现在怎么能改变你必须为哪张幻灯片改变速度。flexslider 的文档没有提供有关在回调函数之后传递哪个参数的任何信息。并且根据这个插件的编码方式,它可能无法即时更改选项,这表明您需要销毁滑块并重新创建一个新的滑块,以保持当前显示的步骤/滑块,奇怪的编码。

所以,我建议你联系这个插件的主要开发者或者尝试自己扩展它。

于 2012-11-07T12:13:08.387 回答