4

我正在制作一个计数器,当文档处于焦点时会倒计时。当它处于模糊状态时,它会停止倒计时。

它在 FF 中工作,但在 Safari 和 Chrome 中,计数器根本不起作用。

Safari/Chrome 是否存在兼容性问题?

我使用的是$(document).blur()and $(document).focus(),并且两者都在一个$(document).ready()块内。

var tm;
$(document).ready(function(){   

        var seconds = 50;
        $('#timer').html(seconds);
        countdown();

    $(window).focus(function(){
         function countdown(){ 
         if (seconds > 0) {
            seconds--; 
            $('#timer').text(seconds);
            tm = setTimeout(countdown,1000);
            }
        if (seconds<=0){ 
            $('#timer').text('Go');
            }   
        }); 



    $(window).blur(function(){
        clearTimeout(tm);
        seconds++;
        $('#timer').text(seconds);

    });
});
4

1 回答 1

13

我一直用$(window).focus()$(window).blur()。试试这些。

另外,请注意,在 FF 和 IE 中,“焦点”事件会在 ~document 加载时触发,而在 Chrome 和 Safari 中,它仅在窗口之前失去焦点并且现在重新获得焦点时才会触发。

UPD:现在,当您粘贴代码时,我对其进行了重新设计以(希望)符合您的目的:

var tm;
var seconds = 50;
var inFocus = true;

function countdown() {
    if (seconds > 0) {
        seconds--;
    }

    if (seconds <= 0) {
        $('#timer').text('Go');
    }
    else {
        $('#timer').text(seconds);
        tm = setTimeout(countdown, 1000);
    }
}

$(function() {
    $('#timer').html(seconds);
    countdown();

    $(window).focus(function() {
         if(!inFocus) {
             countdown();
         }
    });

    $(window).blur(function() {
        inFocus = false;
        clearTimeout(tm);
        seconds++;
        $('#timer').text(seconds);
    });
});
于 2012-04-25T23:21:39.087 回答