我试图延迟此插件中的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);

07-27 13:39