さて、ここで見られるこれらの各課題のカウントダウンを再現しようとしています: http://www.bungie.net/stats/reach/globalchallenges.aspx
問題は、私のカウントダウンを元のカウントダウンと比較すると、約 10 ~ 14 秒の違いがあることです。理由がわかりません。ありがとう!
モバイルページのソース (ソースを表示) を使用して有効期限を取得しています。
<span id="wExpSeconds" title="1304330400000"></span>
<span id="dExpMilliseconds" title="1303984800000"></span>
私のカウントダウンページのソースコードは次のとおりです。
<html>
<head>
<title></title>
<style type="text/css">
.stat{ font: 14px/18px Arial, Helvetica, sans-serif; color:#bbb; }
.seconds{ color:#ff5f3c; }
</style>
</head>
<body>
<div id="countDownDiv"></div>
<script type="text/javascript">
function countDown(id, end, cur){
this.container = document.getElementById(id);
this.endDate = new Date(end);
this.curDate = new Date(cur);
var context = this;
var formatResults = function(day, hour, minute, second){
var displayString = [
'<span class="stat">',day,'d </span>',
'<span class="stat">',hour,'h </span>',
'<span class="stat">',minute,'m </span>',
'<span class="stat seconds">',second,'s</span>'
];
return displayString.join("");
}
var update = function(){
context.curDate.setSeconds(context.curDate.getSeconds()+1);
var timediff = (context.endDate-context.curDate)/1000;
// Check if timer expired:
if (timediff<0){
return context.container.innerHTML = formatResults(0,0,0,0);
}
var oneMinute=60; //minute unit in seconds
var oneHour=60*60; //hour unit in seconds
var oneDay=60*60*24; //day unit in seconds
var dayfield=Math.floor(timediff/oneDay);
var hourfield=Math.floor((timediff-dayfield*oneDay)/oneHour);
var minutefield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour)/oneMinute);
var secondfield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour-minutefield*oneMinute));
context.container.innerHTML = formatResults(dayfield, hourfield, minutefield, secondfield);
// Call recursively
setTimeout(update, 1000);
};
// Call the recursive loop
update();
}
countDown("countDownDiv",1304330400000, new Date().getTime());
</script>
</body>
</html>