滑块向左移动一定量时触发警报
Trigger Alert When Slider Moves Left A Certain Amount
所以,我真的要一举两得。首先,我试图在滑块向左移动到特定程度时触发警报。例如,一旦它进入第三张幻灯片,我希望它能触发警报。此外,我需要帮助循环滑块。我希望滑块像旋转(360)一样循环,但在循环结束时,它会一直滑回起点。查看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);
});
这使用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的布局对我来说很奇怪)
相关文章:
- 正在阻止UIWebView警报
- 当鼠标悬停在文本中的单词上时显示警报
- 为什么JavaScript在for循环为3时向所有4发出警报
- Html引导程序警报自动关闭困难
- 为什么不显示警报窗口
- 刷新页面后会出现警报
- 在mvc应用程序中,在回发时保留最初隐藏的文本框的隐藏或可见状态
- Javascript 将变量分配给警报
- 当var==0时,我如何显示一个警报
- 将JavaScript弹出菜单转换为警报框
- 警报框中的数据通过linq
- 为什么此警报框不't被触发了?在这里追鬼
- 回发时回显值
- 如果连接类型为none,则Javascript Function Only警报
- 从Javascript警报中防止换行
- 如何禁用窗口.当计时器超时时,打开卸载警报
- 构建JS测试,警报窗口重复上一个Q,而不是问下一个Q
- 滑块向左移动一定量时触发警报
- 通过ASP.NET代码中的javascript发出警报后停止回发
- 页面发回错误时,Java脚本警报ok按钮