2

我正在使用带有部分渲染和 ajax 调用的 MVC。在我的一个结果表中,我有一个字段是计时器。

以下代码在我的局部视图上,每 30 秒呈现一次。其中一个字段是向用户显示的活动计时器:

<td><div id="@someID" class="nobutton"></div><script>setInterval(function () { startTimer('@startDateTime', '@someID') }, 500);</script></td>

这很好用,但是在进行 ajax 调用以刷新部分后,间隔函数仍在调用不再存在的旧 ID (someID)。

这是计时器的javascript:

<script type="text/javascript">
    function startTime(dt, field){
        var field = document.getElementById(field);
        if (field == null)
            return;

        var rowTime = new Date(dt);
        var rowTimems = rowTime.getTime(rowTime);

        var currentTime = new Date();
        var currentTimems = currentTime.getTime(currentTime);

        var difference = currentTimems - rowTimems;

        var hours = Math.floor(difference / 36e5),
            minutes = Math.floor(difference % 36e5 / 60000),
            seconds = Math.floor(difference % 60000 / 1000);

        field.innerHTML = formatTime(hours) + ":" + formatTime(minutes) + ":" + formatTime(seconds);
</script>

刷新部分的主页上的调用非常简单:

var t = setInterval(function () {
            $.ajax({
                url: "MYURL",
                type: "GET",
                cache: false,
                success: function (data) {
                    $("#summary").html(data);                    
                }
            });
        }, 30000);

有没有办法杀死老前辈?为什么他们还在跑?

4

2 回答 2

3

代码仍在执行的原因是间隔从未停止过。改为在您的部分中尝试此操作。它将检查前一个间隔计时器是否存在并将其清除。

<td><div id="@someID" class="nobutton"></div>
<script>
 if( window.prtInt != void 0 ) clearInterval(window.prtInt);//void 0 means undefined
 window.prtInt = setInterval(function () { startTimer('@startDateTime', '@someID') }, 500);
</script></td>

如果您希望清除整个页面上的所有计时器(可能会产生不良影响),那么您可以获得新计时器的整数,并循环到仍然存在的那个数字清除间隔。

<script>
 function clrTimers(){
  var clr = setTimeout(function(){},10);
  for( var i = 0; i < clr; i++ ){
   clearInterval(i);
  }
 }
</script>

如果您想跳过一些,那么如果您知道它们,则可以将它们包含在 continue 关键字中。如

for( var i = 0; i < clr; i++ ){
 if( i == t ) continue; //I believe t was your ajax interval variable
 clearInterval(i);
}
于 2013-09-26T23:19:41.573 回答
2
setInterval(function () { startTimer('@startDateTime', '@someID') }, 500);

将继续使用相同的值执行,直到用 清除它clearInterval()。为了清除它,您需要将其保存var并提供给clearInterval()函数。

于 2013-09-26T23:19:33.510 回答