于吉吉的技术博客

建造高性能门户网

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  65 随笔 :: 6 文章 :: 149 评论 :: 0 Trackbacks

最近做了一个房产的秒杀,团购的电子商务网站(房子也有秒杀,出手不小啊),其中里面有一个秒杀的倒计时展示,主要是判断当前时间距离秒杀开始还有多少时间,还有秒杀开始和秒杀结束的各种展示。
其中最主要的一点就是所谓的当前时间不能使用浏览器通过new Date()获取的客户端时间,这样只要用户修改了自己的机器时间那么倒计时就会乱透了,所以这个当前时间必须使用的是服务器时间,所以采用的是静态缓存页面所以这个当前时间使用ajax方式进行获取


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN">
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<meta http-equiv="Content-Language" content="zh-CN" />
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" />
<meta content="all" name="robots" />
<meta name="author" content="" />
</head>
<body onload='start()'>
.
距活动开始还有:<span id="sk_time"></span> <!-- 这个是倒计时的显示 -->
.
<br/>
<span id="wyz">
<span class="btn_02">&nbsp;&nbsp;参加秒杀!!!&nbsp;&nbsp;</span> <!-- 这个是秒杀按钮,倒计时为0时会变成可以秒杀的样式 -->
</span>
.

<script type="text/javascript">
var msbegintime = "1323446400000"//这个是活动开始的时间戳
var msendtime = "1325174400000"//这个是活动结束的时间戳

function start(){
    callBackServerTime(
"sk_time""wyz", msbegintime, msendtime);
}

//_showtimediv:时间显示区域,_showqdiv:状态显示区域
//
这个向服务器发送一个ajax请求,服务器返回服务器当前的时间戳,也就是xmlobj.responseText是一个服务器的时间戳
function callBackServerTime(_showtimediv, _showqdiv, _ms_begintime, _ms_endtime) {
    
var now = new Date();
    
var urlstr = "random=" + Math.round(Math.random() * 10000000);
    
var ajaxobj = new AJAXRequest;    // 创建AJAX对象
    ajaxobj.method = "GET";   // 设置请求方式为GET
    ajaxobj.url = "/gz/source/getServerTime.do?" + urlstr; //注意ajax的跨域问题
    ajaxobj.callback = function(xmlobj) {
        
//ShowQTime(xmlobj.responseText, _showtimediv, _showqdiv, _ms_begintime, _ms_endtime, _tryid,sourceid);
        ShowQTime( _showtimediv, _showqdiv,"1323158067288", _ms_begintime, _ms_endtime);     // 这里使用静态数字替代 xmlobj.responseText 方便测试
    }
    ajaxobj.send();    
// 发送请求
}

//动态显示”秒杀“时间函数
function ShowQTime(_showtimediv, _showqdiv, _nowtime, _ms_begintime, _ms_endtime) {
    _nowtime 
= Number(_nowtime);
    
var timmer = Math.floor((_ms_endtime - _nowtime) / (1000)); 
    
if (_nowtime >= _ms_begintime && timmer > 0) {;
        
//秒杀进行中
        document.getElementById(_showtimediv).innerHTML = "<span class='pim_time'>0</span>天<span class='pim_time'>0</span>小时<span class='pim_time'>0</span>分钟<span class='pim_time'>0</span>秒";
        document.getElementById(_showqdiv).innerHTML 
= "<span class='btn_01'><a href='/gz/sk/v/'>&nbsp;&nbsp;秒杀开始了!!!&nbsp;&nbsp;</a></span>";
    } 
else {
        
//秒杀倒计时
        var nMS = _ms_begintime - _nowtime;  //计算出开始时间和现在时间的时间戳差
        var nD = Math.floor(nMS / (1000 * 60 * 60 * 24));
        
var nH = Math.floor(nMS / (1000 * 60 * 60)) % 24;
        
var nM = Math.floor(nMS / (1000 * 60)) % 60;
        
var nS = Math.floor(nMS / 1000% 60;
        
var nMS = Math.floor(nMS / 100% 10;
        
if (nD >= 0) {
            
var _timestr = "";
            
var snd = nD.toString();
            
if (snd.length == 1) {
                snd 
= "0" + snd;
            }
            _timestr 
+= "<span class='pim_time'>" + snd.substring(01+ snd.substring(12+"</span>天";
            
var snH = nH.toString();
            
if (snH.length == 1) {
                snH 
= "0" + snH;
            }
            _timestr 
+= "<span class='pim_time'>" + snH.substring(01+ snH.substring(12+"</span>小时";
            
var snM = nM.toString();
            
if (snM.length == 1) {
                snM 
= "0" + snM;
            }
            _timestr 
+= "<span class='pim_time'>" + snM.substring(01+ snM.substring(12+"</span>分钟";
            
var snS = nS.toString();
            
if (snS.length == 1) {
                snS 
= "0" + snS;
            }
            _timestr 
+= "<span class='pim_time'>" + snS.substring(01+ snS.substring(12+"</span>秒";
            document.getElementById(_showtimediv).innerHTML 
= _timestr;
        }
else {
            
//秒杀结束
             document.getElementById(_showtimediv).innerHTML = "<span class='pim_time'>0</span>天<span class='pim_time'>0</span>小时<span class='pim_time'>0</span>分钟<span class='pim_time'>0</span>秒";
             document.getElementById(_showqdiv).innerHTML 
= "<span class='btn_01'><a href='/gz/sk/v/'>&nbsp;&nbsp;秒杀结束了!!!&nbsp;&nbsp;</a></span>";
        }
    }
    
//注意 (_nowtime + 1000) 增加 1 秒
    setTimeout("ShowQTime('" + _showtimediv + "','" + _showqdiv + "','" + (_nowtime + 1000+ "','" + _ms_begintime + "','" + _ms_endtime + "')"1000);
}

function AJAXRequest() {
    
var xmlObj = false;
    
var CBfunc,ObjSelf;
    ObjSelf
=this;
    
try { xmlObj=new XMLHttpRequest; }
    
catch(e) {
        
try { xmlObj=new ActiveXObject("MSXML2.XMLHTTP"); }
        
catch(e2) {
            
try { xmlObj=new ActiveXObject("Microsoft.XMLHTTP"); }
            
catch(e3) { xmlObj=false; }
        }
    }
    
if (!xmlObj) return false;
    
this.method="POST";
    
this.url;
    
this.async=true;
    
this.content="";
    
this.callback=function(cbobj) {return;}
    
this.send=function() {
        
if(!this.method||!this.url||!this.async) return false;
        xmlObj.open (
this.method, this.url, this.async);
        
if(this.method=="POST") xmlObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
        xmlObj.onreadystatechange
=function() {
            
if(xmlObj.readyState==4) {
                
if(xmlObj.status==200) {
                    ObjSelf.callback(xmlObj);
                }
            }
        }
        
if(this.method=="POST") xmlObj.send(this.content);
        
else xmlObj.send(null);
    }
}
</script>

</body>
</html>
posted on 2011-12-06 16:22 陈于喆 阅读(4961) 评论(7)  编辑  收藏 所属分类: web开发

评论

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2011-12-07 08:49 tb
不错的例子  回复  更多评论
  

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2011-12-07 09:21 HiMagic!
用了jQuery怎么还自己封ajax。有没有测过误差堆积,就是说当页面跑上十几分钟后,看看时钟是否还正确。  回复  更多评论
  

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2011-12-07 14:42 TBW
这个真不错哦  回复  更多评论
  

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2011-12-07 17:06 雪地靴
难怪那么多团购网的,是这么回事。  回复  更多评论
  

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2011-12-15 17:37 raullf
很好的东西,哪里用了jquery!  回复  更多评论
  

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2012-02-29 11:41 新款女装
写得非常好,没事的时候学来看看,
亲亲网 www.5a77.com
新款女装 www.a0a7.com  回复  更多评论
  

# re: javascript 实现'秒杀,团购'倒计时展示的记录 2014-04-15 14:16 Mr.Ding
在其他网站也看到过类似的实现"有没有测过误差堆积"确实是个问题,解决方案隔一段时间发ajax获取一次数据库当前时间@HiMagic!  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: