javascript - 关闭倒计时的灯箱

标签 javascript jquery lightbox

我的问题是,我第一次看到计时器开始计时,但之后就变得奇怪了,最后浏览器崩溃了。

我将给出错误的代码放在这里,这是一个巨大的东西,所以我不能把它全部放在这里。

JavaScript:

// display the lightbox
function lightbox(insertContent) {

    // jQuery wrapper (optional, for compatibility only)
    (function($) {
        // add lightbox/shadow <div/>'s if not previously added
        if ($('#lightbox').size() === 0) {
            var theLightbox = $('<div id="lightbox"/>');
            var theShadow = $('<div id="lightbox-shadow"/>');
            var countDown = $('<div class="countDown"/>');
            $(theShadow).click(function(e) {
                closeLightbox();
            });
            $('body').append(theShadow);
            $('body').append(theLightbox);
            $('body').append(countDown);
        }

        // insert HTML content
        if (insertContent !== null) {
            $('#lightbox').html(insertContent);
            $('#lightbox').corner("15px");

            // ALWAYS LAST
            //$('#lightbox').append(countDown);
            CountDown(5);
        }

        // move the lightbox to the current window top + 100px
        $('#lightbox').css('top', $(window).scrollTop() + 100 + 'px');
        $('#lightbox-shadow').css('top', $(window).scrollTop());
        $('.countDown').css('top', $(window).scrollTop() + 150 + "px");

        // display the lightbox
        $('#lightbox').show();
        $('#lightbox-shadow').show();
        $('.countDown').show();

    })(jQuery); // end jQuery wrapper
}

function CountDown(tiempo) {
    if (tiempo <= 0) {
        clearInterval(IntervalID);
        closeLightbox();
    } else {
        $(".countDown").html("Esta ventana se cerrará en " + tiempo + " segundos");
        tiempo--;
    }
    var IntervalID = setInterval("CountDown(" + tiempo + ")", 1000);
}

// close the lightbox


function closeLightbox() {

    // jQuery wrapper (optional, for compatibility only)
    (function($) {

        // hide lightbox/shadow <div/>'s
        $('#lightbox').hide();
        $('#lightbox-shadow').hide();
        $('.countDown').hide();

        // remove contents of lightbox in case a video or other content is actively playing
        $('#lightbox').empty();

    })(jQuery); // end jQuery wrapper
};

$(document).ready(function() {
    $("#Login").click(function(event) {
        event.preventDefault();
        lightbox("Username Not Available");
        $("#lightbox").css("color", "#FF0000");
    });
});

HTML:

<input type="button" id="Login" value="Hello">

CSS:

#lightbox {
    position: absolute;
    width: 50%;
    left: 25%;
    background: #fff;
    z-index: 1001;
    display: none;

    color: #069;
    padding: 20px;
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    font-variant: small-caps;
    text-shadow: 1px 1px #000;
}
#lightbox-shadow {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    filter: alpha(opacity=90);
    -moz-opacity: 0.90;
    -khtml-opacity: 0.90;
    opacity: 0.90;
    z-index: 1000;
    display: none;
}

.countDown {
    position: absolute;
    width: 50%;
    left: 25%;
    background: #fff;
    z-index: 1002;
    display: none;

    color: #069;
    padding: 20px;
    text-align: center;
    font-size: 18px;
    font-variant: small-caps;
    font-weight: normal;
    margin: 10px auto;
    display: none;
}

JsFiddle:

http://jsfiddle.net/c2gx9/6/

不知道为什么它在 jsfiddle 上不起作用;它在我的电脑上运行良好。

最佳答案

只是一个建议,尝试使用 jsbin 而不是 jsfiddle。你的 fiddle 在 jsbin 上比在 jsfiddle 上工作得更好。

无论如何,在 closeLightbox 中,您正在执行 $('#lightbox').empty(); 这将删除所有子项,但保留父项。意思是清除 lightbox 后,仍然有一个 id 为 lightbox 的 div。

第二次调用 lightbox 时,条件 $('#lightbox').size() === 0 的计算结果为 false,因为元素已经存在。

要解决此问题,请将行 $('#lightbox').empty(); 替换为 $('#lightbox').remove();

代码的第二个问题是调用 setInterval 的方式。

function CountDown(tiempo) {
    if (tiempo <= 0) {
        clearInterval(IntervalID);
        closeLightbox();
    } else {
        $(".countDown").html("Esta ventana se cerrará en " + tiempo + " segundos");
        tiempo--;
    }

    var IntervalID = setInterval("CountDown(" + tiempo + ")", 1000);
}

js引擎将代码翻译成这样

function CountDown(tiempo) {
    var IntervalID;

    if (tiempo <= 0) {
        clearInterval(IntervalID);
        closeLightbox();
    } else {
        $(".countDown").html("Esta ventana se cerrará en " + tiempo + " segundos");
        tiempo--;
    }

    IntervalID = setInterval("CountDown(" + tiempo + ")", 1000);
}

IntervalID 是函数的局部变量。每次调用该函数时,都会从头开始创建变量。所以实际上,你永远不会清除间隔。您只是递减 tiempo 变量。

“浏览器变得疯狂”的一个可能原因是只执行一次 setInterval 将重复调用指定的函数,直到明确停止。在倒计时中,超过 5 次迭代,您将调用 setInterval 5 次。您可以想象,经过几次尝试后,浏览器会因所有这些同时运行的 CountDown 实例而重载。

将来如果你想使用setInterval,你可能想要read the documentation at MDN .该站点是一个非常好的 HTML、JS 和 CSS 资源。

最后,您将函数名称作为字符串参数传递给 setInterval。由于各种原因,它有点不受欢迎。我选择不这样做的原因是,只有当该函数可全局访问时,代码才能工作。为了封装和不污染全局命名空间,人们推荐其他方法。

回到如何解决这个问题,我应该第一时间注意到 setInterval 错误。我没有,那是我的错。您已经找到适合您的解决方案。为了完整起见,我将包括我将如何要求您修复它。

function CountDown(tiempo) {
    if (tiempo <= 0) {
        closeLightbox();

    } else {
        $(".countDown").html("Esta ventana se cerrará en " + tiempo + " segundos");
        tiempo--;

        setTimeout(function () { 
            CountDown(tiempo);
        }, 1000);
    }
}

关于javascript - 关闭倒计时的灯箱,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13543335/

相关文章:

jquery - 将 Swipebox Caption 从标题属性更改为 Alt 标签或 Caption 标签

jquery - 图片放在其他图片后面(砌体插件)

&lt;input&gt; 上 HTML5 "pattern"属性的 Javascript 回退

javascript - 如何解析以下代码中的 "cannot read property appendChild of null"?

javascript - 在页面加载时显示整页覆盖

javascript - Twitter Bootstrap 选项卡 : Go to Specific Tab on Page Reload or Hyperlink

css - 添加灯箱时,我的下拉菜单显示在图像顶部

jquery - 这个语法在 jquery 中是否正确

jquery - 如何使用 Jquery 或其他简单操作在创建 View 上隐藏或显示表单组。 ASP.NET MVC 5

javascript - 我需要运行这个函数两次