我有一个愚蠢的网站请求 - 他们希望悬停状态动画,因为他们认为没有人会知道那里有链接...
无论如何......我创建了一个幻灯片,以显示我正在尝试创建的效果 - 但现在我无法使用jQuery代码。我在这里找到了我认为的答案:Trying to loop between CSS classes/hover states - Jquery
但即使合并了这个新代码,动画/切换也无效。
我认为我错过了一些明显的东西 - 有人可以帮忙吗?
这是幻灯片版本,以显示我想要的效果: http://test.fatcat-studios.com/gtm/index.html 但我想用jQuery做到这一点,所以当你与它进行交互时,正确的悬停状态显示在实际鼠标悬停时。
这是我的jQuery代码:
$(function() {
var doToggle = true;
$('a.res').removeClass('hover');
$('a.com').addClass('hover');
var tid = setInterval( function() {
if (doToggle) $('a.res, a.com').toggleClass('hover');
}, 2000);
setTimeout(function() {
if (tid) clearInterval(tid);
$('a.res,a.com').removeClass('hover');
}, 30000); // stop toggling after 30 seconds
$('a.res,a.com').hover( function() {
doToggle = false;
}, function() {
doToggle = true;
});
});
非常感谢任何帮助!如果需要更多信息,请告诉我。 Haikukitty
答案 0 :(得分:1)
AFAIK无法用JS模拟CSS悬停状态。但是,如果你想要一个简单的jQuery解决方案,这应该做你想要的(fiddle)。
CSS(使用:hover伪类)
#clicky {
color:#000;
}
#clicky:hover {
color:#FFBF00;
}
JS
yep = true; // just a global var to stop it flashing when the user hovers
// you may want to persist this differently
$(function() {
setInterval(function() {
if (yep) {
var $c = $('#clicky');
$c.css({color: $c.hasClass('active') ? '#000' : '#FFBF00'}).toggleClass('active');
}
}, 1 * 1000);
$('#clicky').hover(function() {
yep = false;
}, function() {
yep = true;
});
});
答案 1 :(得分:1)
试试这个:
$(function() {
var autoToggle = true;
var $togglers = $('a.res, a.com');
var tid_1,
tid_2 = setTimeout(function() {
clearInterval(tid_1);
$togglers.removeClass('hover');
autoToggle = false;
}, 30000); // stop toggling after 30 seconds
$togglers.hover(function() {
clearInterval(tid_1);
$togglers.removeClass('hover');
$(this).addClass('hover');
}, function() {
if(autoToggle) {
$('a.res').removeClass('hover');
$('a.com').addClass('hover');
tid_1 = setInterval(function() {
$togglers.toggleClass('hover');
}, 2000);
}
else {
$togglers.removeClass('hover');
}
}).triggerHandler('mouseout');
});