当滑块向左移动一定数量时触发警报

时间:2015-04-06 04:11:37

标签: javascript jquery slider alert setinterval

所以,我真的要一石二鸟。首先,我试图在滑块向左移动到特定程度时触发警报。例如,一旦它进入,比方说,我希望第三张幻灯片触发警报。另外,我需要滑块循环的帮助。我希望滑块像旋转一样循环(360),但是在循环结束时它会一直滑回到开始。查看Codepen以更好地理解我的意思。感谢您的时间。非常感谢您的帮助。

Live Codepen

var W = $('#image_rotator').width(),
N = $('#slider .slide').length,
C = 0,
intv;

if (N <= 1) $('#left, #right').hide();
$('#slider').width(W * N);

$('#left, #right').click(function() {
C = (this.id == 'right' ? ++C : --C) < 0 ? N - 1 : C % N;
$('#slider').stop().animate({
left: -C * W
}, 300);
});

function setResetInterval(e) {

var intv = $("#slider");
if (e) {
timer = setInterval(function() {
$('#right').click();
}, 1000);
} else {
clearInterval(timer);
}

$('#slider').click(function() {
var x = $('#slider').offset();
alert("Top: " + x.top + " Left: " + x.left);
});
}

$("#btn").click(function(e) {
e.preventDefault();
setResetInterval(true);
});
$("#btn2").click(function(e) {
e.preventDefault();
setResetInterval(false);
});
$('#slider').hover(function(e) {
return e.type == 'mouseenter' ? setResetInterval(false) : setResetInterval(true);
});

1 个答案:

答案 0 :(得分:0)

这使用animate函数中的可选回调参数完成了您想要的两件事。它首先检查变量C(当前幻灯片的从0开始的索引)是否等于2(基于1的索引中为3),如果是,则显示警报。然后它检查C是否等于10(这意味着当前显示的幻灯片是第9个;第9个图像只是第1个的副本)如果它是第9个,那么跳回到第一个并触发$("#right").click();

$('#left, #right').click(function() {
    C = (this.id == 'right' ? ++C : --C) < 0 ? N - 1 : C % N;
    $('#slider').stop().animate({
        left: -C * W
    }, 300, function() {
        if (C == 2){alert("3rd");}
        if (C == 10) {
            $('#slider').css("left", "0");
            $('#right').click();
        }
    });
});

JSFiddle(因为CodePen的布局对我来说很奇怪)