我正在网站上显示一个消息框。我希望能够在点击或X秒后淡出。问题是delay()
函数取代了click()
函数,因此即使你点击关闭,你仍然需要等待时间。
这是jQuery
$(document).ready(function() {
$(".close-green").click(function () {
$("#message-green").fadeOut("slow");
});
//fade out in 5 seconds if not closed
$("#message-green").delay(5000).fadeOut("slow");
})
我还设置了一个简单的jsfiddle。要查看问题,请注释延迟行http://jsfiddle.net/BandonRandon/VRYBk/1/
答案 0 :(得分:22)
您应该将其更改为setTimeout
:
http://jsfiddle.net/VRYBk/3/
(在jsfiddle链接中)
我删除了您的延迟行,并将其替换为标准setTimeout
,如:
setTimeout(function(){
$("#message-green").fadeOut("slow");
},5000)
作为原因的说明,是因为JS从上到下阅读,它会在您点击并触发事件之前读取延迟。因此,即使您单击正在运行的延迟,也会导致所有动画暂停。
答案 1 :(得分:7)
这将是jQuery 1.5的新Deferred对象的理想用法:
// a deferred object for later processing
var def = $.Deferred();
// resolve the deferred object on click or timeout
$(".close-green").click(def.resolve);
setTimeout(def.resolve, 5000);
// however the deferred object is resolved, start the fade
def.done(function() {
$(".message-green").fadeOut("slow");
});
的工作演示
请注意,如果按下按钮,定时器仍然会触发,则无关紧要 - 忽略对def.resolve()
的第二次调用。
答案 2 :(得分:1)
我认为它是Oscar Godson建议的最好的解决方法,我不知怎的把它添加到它:
if (! $clicked.hasClass("search"))
{
setTimeout(function()
{
jQuery("#result").delay('1500').fadeOut('2800');
},7000);
}
});
他最初的建议非常有用:
您应该将其更改为setTimeout:http://jsfiddle.net/VRYBk/3/
(在jsfiddle链接中) 我删除了你的延迟线,并将其替换为标准的setTimeout,如:
setTimeout(function(){
$("#message-green").fadeOut("slow");
},5000)
奥斯卡·龙森,