JavaScript倒计时获取服务器时间

之前写过一篇:jQuery手机验证码倒计时效果,本文讲另外一种一个阶段的倒计时,这就需要用到服务器时间,毕竟本机时间可以人为的修改。

//获取服务器时间
function getSevertime(){
var xmlHttp = new XMLHttpRequest();
if( !xmlHttp ){
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlHttp.open("HEAD",location.href,false);
xmlHttp.send();
var severtime=new Date(xmlHttp.getResponseHeader("Date"));
return severtime;
}

其他的使用方式跟正常的使用js一致,只是相比平时我们获取的是本机时间会比较准确和不会产生bug.常用获取服务器时间在倒计时应用中,例如以下,倒计时:

//换奖活动兑奖倒计时
var clockTime = null;
var clockRuning = false;
function setClock(){
    // var now = new Date();
    var now = getSevertime();
    var endTime = new Date('2016/01/16 10:00:00');
    var t = endTime.getTime() - now.getTime();
    if(t < 0) clearInterval(clockTime);
      var d=Math.floor(t/1000/60/60/24);
       var h=Math.floor(t/1000/60/60%24);
       var m=Math.floor(t/1000/60%60);
       var s=Math.floor(t/1000%60);
    var _html = '';
    if(d>0) _html += '<span class="muted">'+d+'</span><span class="span">天</span>';
    if(h>=10) _html += '<span class="muted">'+h.toString().slice(0,1)+'</span><span class="muted">'+h.toString().slice(1,2)+'</span><span class="span2">:</span>';
    if(h<10) _html += '<span class="muted">0</span><span class="muted">'+h+'</span><span class="span2">:</span>';
    if(m>=10) _html += '<span class="muted">'+m.toString().substring(0,1)+'</span><span class="muted">'+m.toString().substring(1,2)+'</span>';
    if(m<10) _html += '<span class="muted">0</span><span class="muted">'+m+'</span>';
    if(getId('clockTime')){
        getId('clockTime').innerHTML = _html;
    }
}
setClock();//初始化
var clockTime = setInterval(setClock,60000);

显示效果如下:

daojishi

「五年博客,如果觉得我的文章对您有用,请帮助本站成长」

订阅周报 关注微博

原创文章:JavaScript倒计时获取服务器时间 ,未经许可,禁止转载,©版权所有
原文出处:前端开发博客 (http://caibaojian.com/daojishi-2.html)

发表评论

请登录后发表评论: