如何在x秒后关闭精益模态弹出窗口?

时间:2014-09-15 13:36:28

标签: javascript jquery

好的,所以我正在使用精益模态脚本,我想在它处理我的代码后自动关闭3秒后。精益模态脚本如下所示:

(function($) {
    $.fn.extend({
        leanModal: function(options) {
            var defaults = {
                top: 100,
                overlay: 0.5,
                closeButton: null
            };
            var overlay = $("<div id='lean_overlay'></div>");
            $("body").append(overlay);
            options = $.extend(defaults, options);
            return this.each(function() {
                var o = options;
                $(this).click(function(e) {
                    var modal_id = $(this).attr("href");
                    $("#lean_overlay").click(function() {
                        close_modal(modal_id)
                    });
                    $(o.closeButton).click(function() {
                        close_modal(modal_id)
                    });
                    var modal_height = $(modal_id).outerHeight();
                    var modal_width = $(modal_id).outerWidth();
                    $("#lean_overlay").css({
                        "display": "block",
                        opacity: 0
                    });
                    $("#lean_overlay").fadeTo(200, o.overlay);
                    $(modal_id).css({
                        "display": "block",
                        "position": "fixed",
                        "opacity": 0,
                        "z-index": 11000,
                        "left": 50 + "%",
                        "margin-left": -(modal_width / 2) + "px",
                        "top": o.top + "px"
                    });
                    $(modal_id).fadeTo(200, 1);
                    e.preventDefault()
                })
            });

            function close_modal(modal_id) {
                $("#lean_overlay").fadeOut(200);
                $(modal_id).css({
                    "display": "none"
                })
            }
        }
    })
})(jQuery);

模态窗口在主索引页面上打开,但另一个php脚本处理此模式窗口中的表单。我需要在处理页面中使用哪些JavaScript代码来关闭它?提前谢谢。

尝试使用它来关闭它,但只会关闭弹出容器周围的低不透明度:

setTimeout(function(){ 

                $("#lean_overlay").fadeOut(200);
                $(modal_id).css({
                    "display": "none"
                })
                $(".popupContainer").fadeOut(200);
                $(modal_id).css({
                    "display": "none"
                })
                $(".popupBody").fadeOut(200);
                $(modal_id).css({
                    "display": "none"
                })


            }, 3000);

1 个答案:

答案 0 :(得分:7)

你可以触发点击叠加关闭模态或触发点击关闭按钮(如果有的话)。 试试这个。

$("#lean_overlay").trigger("click");