一段JS的服务器时间倒记时器

 

一段JS的服务器时间倒记时器

我做了一下修改。。

来源:http://www.dynamicdrive.com/dynamicindex6/universalcountdown.htm

<% @ Page Language = " C# "  AutoEventWireup = " true "   %>
<% @ Import Namespace = " System.Globalization "    %>
<! 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 = " en "  xml:lang = " en " >
< head runat = " server " >
< meta http - equiv = " Content-Type "  content = " text/html; charset=iso-8859-1 "   />
< title > Dynamic Drive DHTML Scripts -  Universal Countdown Script </ title >
< link rel = " stylesheet "  type = " text/css "  href = " ../ddincludes/mainstyle.css "   />

< style style = " text/css " >

.lcdstyle
/*Example CSS to create LCD countdown look*/
background
-color:black;
color:lime;
font: bold 18px MS Sans Serif;
padding: 3px;
}


.lcdstyle sup
/*Example CSS to create LCD countdown look*/
font
-size: 80%
}


</ style >

< script type = " text/javascript " >

/***********************************************
* Universal Countdown script- ?Dynamic Drive (
http://www.dynamicdrive.com)
* This notice MUST stay intact for legal use
* Visit 
http://www.dynamicdrive.com/ for this script and 100s more.
**********************************************
*/



function cdLocalTime(container, servermode, offsetMinutes, targetdate, debugmode)
{
if (!document.getElementById || !document.getElementById(container)) return
this.container=document.getElementById(container)
var servertimestring
=(servermode=="server-php")? '<? print date("F d, Y H:i:s", time())?>' : (servermode=="Server-Aspx")? '<%=DateTime.Now.ToString("MMMM dd, yyyy HH:mm:ss", new CultureInfo("en-US")) %>' : '<%=DateTime.Now.ToString("MMMM dd, yyyy HH:mm:ss", new CultureInfo("en-US")) %>'
this.localtime=this.serverdate=new Date(servertimestring)
this.targetdate=new Date(targetdate)
this.debugmode=(typeof debugmode!="undefined")? 1 : 0
this.timesup=false
this.localtime.setTime(this.serverdate.getTime()+offsetMinutes*60*1000//add user offset to server time
this.updateTime()
}


cdLocalTime.prototype.updateTime
= function() {
var thisobj
=this
this.localtime.setSeconds(this.localtime.getSeconds()+1)
setTimeout(function()
{thisobj.updateTime()}1000//update time every second
}


cdLocalTime.prototype.displaycountdown
= function(baseunit, functionref) {
this.baseunit=baseunit
this.formatresults=functionref
this.showresults()
}


cdLocalTime.prototype.showresults
= function() {
var thisobj
=this
var debugstring
=(this.debugmode)? "<p style="background-color: #FCD6D6; color: black; padding: 5px"><big>Debug Mode on!</big><br /><b>Current Local time:</b> "+this.localtime.toLocaleString()+"<br />Verify this is the correct current local time, in other words, time zone of count down date.<br /><br /><b>Target Time:</b> "+this.targetdate.toLocaleString()+"<br />Verify this is the date/time you wish to count down to (should be a future date).</p>" : ""

var timediff
=(this.targetdate-this.localtime)/1000 //difference btw target date and current date, in seconds
if (timediff<0)//if time is up
this.timesup=true
this.container.innerHTML=debugstring+this.formatresults()
return
}

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))
if (this.baseunit=="hours")//if base unit is hours, set "hourfield" to be topmost level
hourfield=dayfield*24+hourfield
dayfield
="n/a"
}

else if (this.baseunit=="minutes")//if base unit is minutes, set "minutefield" to be topmost level
minutefield=dayfield*24*60+hourfield*60+minutefield
dayfield
=hourfield="n/a"
}

else if (this.baseunit=="seconds")//if base unit is seconds, set "secondfield" to be topmost level
var secondfield=timediff
dayfield
=hourfield=minutefield="n/a"
}

this.container.innerHTML=debugstring+this.formatresults(dayfield, hourfield, minutefield, secondfield)
setTimeout(function()
{thisobj.showresults()}1000//update results every second
}


/////CUSTOM FORMAT OUTPUT FUNCTIONS BELOW//

// Create your own custom format function to pass into cdLocalTime.displaycountdown()
// Use arguments[0] to access "Days" left
// Use arguments[1] to access "Hours" left
// Use arguments[2] to access "Minutes" left
// Use arguments[3] to access "Seconds" left

// The values of these arguments may change depending on the "baseunit" parameter of cdLocalTime.displaycountdown()
// For example, if "baseunit" is set to "hours", arguments[0] becomes meaningless and contains "n/a"
// For example, if "baseunit" is set to "minutes", arguments[0] and arguments[1] become meaningless etc

// 1) Display countdown using plain text
function formatresults() {
if (this.timesup==false){//if target date/time not yet met
var displaystring="<span style='background-color: #CFEAFE'>"+arguments[1]+" hours "+arguments[2]+" minutes "+arguments[3]+" seconds</span> left until April 23, 2008 2:30:25 Pacific Time (GMT-8)"
}

else//else if target date/time met
var displaystring="Launch time!"
}

return displaystring
}


// 2) Display countdown with a stylish LCD look, and display an alert on target date/time
function formatresults2() {
if (this.timesup==false)//if target date/time not yet met
var displaystring="<span class='lcdstyle'>"+arguments[0]+" <sup>days</sup> "+arguments[1]+" <sup>hours</sup> "+arguments[2]+" <sup>minutes</sup> "+arguments[3]+" <sup>seconds</sup></span> left until April 23, 2010 15:53:00 Pacific Time (GMT-8)"
}

else//else if target date/time met
var displaystring="" //Don't display any text
alert("Launch time!"//Instead, perform a custom alert
}

return displaystring
}


</ script >

</ head >

< body >


< form runat = " server " >
    


< div id = " cdcontainer " ></ div >

< div id = " cdcontainer2 "  style = " margin: 10px 0 1em 0; " ></ div >


< script type = " text/javascript " >
// cdLocalTime("ID_of_DIV_container", "server_mode", LocaltimeoffsetMinutes, "target_date", "opt_debug_mode")
// cdLocalTime.displaycountdown("base_unit", formatfunction_reference)

var launchdate
= new  cdLocalTime( " cdcontainer " " None " 0 " April 23, 2008 2:30:25 " )
launchdate.displaycountdown(
" hours " , formatresults)

var launchdate2
= new  cdLocalTime( " cdcontainer2 " " Server-Aspx " 0 " April 23, 2008 2:30:25 " )
launchdate2.displaycountdown(
" days " , formatresults2)

</ script >

</ form >

</ body >

</ html >
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值