我试图延迟此插件中的addclass
函数,但是它不起作用。我在.delay(14000)
函数之前添加了.addClass
。
码:
if (typeof a.cookieguard.displayMessage === "undefined") {
a.cookieguard.displayMessage = function (b, c) {
a("body").delay(14000)
.addClass("cookie-guard")
.attr("marginTop", a("body").css("marginTop"))
.css("margin", 0)
.delay(b).animate({
marginTop: a(".cookie-guard-msg").outerHeight()
}, a.cookieguard.settings.slideSpeed);
a(".cookie-guard-msg").css("top", -a(".cookie-guard-msg").outerHeight());
a(".cookie-guard-msg").delay(b)
.show()
.animate({top: 0}, a.cookieguard.settings.slideSpeed);
if (a.cookieguard.settings.messageHideDelay != null) {
a.cookieguard.settings.messageHideTimeout = setTimeout(function () {
a.cookieguard.hideMessage(0)
}, c)
}
}
}
我究竟做错了什么?
最佳答案
jQuery的.delay()
仅适用于使用jQuery效果队列的调用(类似于常见的动画)。
要在这里执行您需要的操作,我将使用常规的JavaScript setTimeout
:
setTimeout(function() { a("body").addClass("cookie-guard"); /* etc. */ }, 14000);