1.当鼠标悬停/关闭图像时如何暂停/停止/继续动画?
当我的鼠标悬停在我的图像上时,我希望图像在鼠标悬停在其上时暂停。然后我希望它在鼠标不在图像时继续滚动图像。
jQuery(function ($){
// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'li'; // could also use 'img' if you're not using a ul
var $transition_time = 4000; //millseconds
var $time_between_slides = 1000; //millseconds
var $stopAnimating = true;
var timeout;
function slides() {
return $slider.find($slide);
}
slides().fadeOut();
// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);
$interval = '';
// auto scroll
$interval = setInterval(function (){
var $i = $slider.find($slide + '.active').index();
slides().eq($i).removeClass('active');
slides().eq($i).fadeOut($transition_time);
if (slides().length == $i + 1) $i = -1; // loop to start
slides().eq($i + 1).fadeIn($transition_time);
slides().eq($i + 1).addClass('active');
}, $transition_time + $time_between_slides);
slides().mouseover(function () {
slides().stop;
setInterval = 0;
alert('mousein');
});
slides().mouseout(function () {
alert('mouseout');
});
});
这很容易做到。但它显然是我在该领域的新人 谢谢
答案 0 :(得分:-1)
你很幸运@ user2512393因为我已经弄清楚了。这个link会对您有所帮助。
在函数中包装区间,声明区间变量,将函数返回到外部并将悬停设置为新构建的函数。
jQuery(function ($) {
// settings
var $slider = $('.slider'); // class or id of carousel slider
var $slide = 'img'; // could also use 'img' if you're not using a ul
var $transition_time = 1000; // 1 second
var $time_between_slides = 4300; // 4 seconds
var $interval;
function slides() {
return $slider.find($slide);
}
slides().fadeOut();
// set active classes
slides().first().addClass('active');
slides().first().fadeIn($transition_time);
// auto scroll
function startloop(){
$interval = setInterval(
function () {
var $i = $slider.find($slide + '.active').index();
slides().eq($i).removeClass('active');
slides().eq($i).fadeOut($transition_time);
if (slides().length == $i + 1) $i = -1; // loop to start
slides().eq($i + 1).fadeIn($transition_time);
slides().eq($i + 1).addClass('active');
}, $transition_time + $time_between_slides);
}
function pauseLoop() {
window.clearInterval($interval);
}
$(".slider").hover(
function () {
//alert("pause");
pauseLoop(); // pause the loop
},
function () {
//alert("unpause");
startloop(); //scroll()
});
return startloop();
});
此代码位于github。
现在,我正在尝试实施触摸检测以将其暂停在移动设备上。