悬停时暂停幻灯片放映

时间:2016-06-28 05:16:58

标签: javascript jquery slider slideshow mousehover

我有以下脚本来运行幻灯片,这很好用。

jQuery(document).ready(function ($) {


setInterval(function () {
    moveRight();
}, 5000);


var slideCount = $('#slider ul li').length;
var slideWidth = $('#slider ul li').width();
var slideHeight = $('#slider ul li').height();
var sliderUlWidth = slideCount * slideWidth;

$('#slider').css({ width: slideWidth, height: slideHeight });

$('#slider ul').css({ width: sliderUlWidth, marginLeft: - slideWidth });

$('#slider ul li:last-child').prependTo('#slider ul');

function moveLeft() {
    $('#slider ul').animate({
        left: + slideWidth
    }, 500, function () {
        $('#slider ul li:last-child').prependTo('#slider ul');
        $('#slider ul').css('left', '');
    });
};

function moveRight() {
    $('#slider ul').animate({
        left: - slideWidth
    }, 500, function () {
        $('#slider ul li:first-child').appendTo('#slider ul');
        $('#slider ul').css('left', '');
    });
};

$('a.control_prev').click(function () {
    moveLeft();
});

$('a.control_next').click(function () {
     moveRight();
});
});

但是我希望它暂停鼠标悬停,我已经尝试了一些我在SO上找到的其他建议(包括下面的那些),但是无法使它们中的任何一个与代码一起工作我有。 有任何想法吗?感谢。

$("#slider ul").mouseover(function() {
$("#slider ul").trigger('pause', true);
});

4 个答案:

答案 0 :(得分:2)

您可以使用.stop()clearInterval()

// define reference to `setInterval()` call
var interval = setInterval(function () {
    moveRight();
}, 5000);

// stop animations, clear `interval`
$("#slider ul").mouseover(function() {
  $(this).stop();
  clearInterval(interval);
});

答案 1 :(得分:0)

您可以使用clearInterval()删除间隔。

答案 2 :(得分:0)

希望这会有所帮助:

var timerObject=null; 

function StartSlide(){
timerObject = setInterval(function () {
    moveRight();
}, 5000);
}

function stopSlide(){
clearInterval(timerObject)
}

$("#slider ul").mouseover(function() {
stopSlide()
});

$("#slider ul").mouseleave(function() {
StartSlide()
});

答案 3 :(得分:0)

.stop() | jQuery API

JSfiddle示例: