倒数计时器在减去而不是在0天00:00:00停止

时间:2016-06-12 06:43:03

标签: c# jquery asp.net jquery-countdown

我正在处理asp.net,jQuery,C#中的倒计时器的这段代码。

我有倒数计时器的这个jQuery代码:

<div id="timelabel"></div>
<script type="text/javascript">
var leave = <%=seconds %>;
CounterTimer();

var interv = setInterval(CounterTimer,1000);

function CounterTimer()
{
    var day = Math.floor(leave / ( 60 * 60 * 24))
    var hour = Math.floor(leave / 3600) - (day * 24)
    var minute = Math.floor(leave / 60) - (day * 24 *60) - (hour * 60)
    var second = Math.floor(leave) - (day * 24 *60*60) - (hour * 60 * 60) -(minute*60)

    hour = hour < 10 ? "0" + hour : hour;
    minute = minute < 10 ? "0" + minute : minute;
    second = second<10 ? "0" + second : second;

    var remain = day + " days   " + hour + ":" + minute + ":" + second;
    leave = leave - 1;

    document.getElementById("timelabel").innerText = remain;
}
</script>

我从文件后面的代码传递结束日期是.cs:

public double seconds;

protected void Page_Load(object sender, EventArgs e)
{
    seconds = (GetEndTime() - GetStartTime()).TotalSeconds;
}

private DateTime GetStartTime()
{
    return DateTime.Now;
}

private DateTime GetEndTime()
{
    return new DateTime(2016, 6, 12, 11, 57, 00); //end date yr-month-day hr-mnt-sec
}

我遇到一个问题,这个计时器在0:00 00:00:00到达时不会停止 它超越了-1天23:48:20。我想解决这个问题,因为我对jQuery没有那么多的知识我发现它很难,所以有人可以指导我进行必要的修改吗?请帮忙。提前谢谢。

1 个答案:

答案 0 :(得分:0)

你需要在它达到0或更高之后清除间隔。将其添加到CounterTimer函数的底部。

if(leave <= 0) clearInterval(interv);