您的位置:首页 > Web前端 > JavaScript

JS的服务器时间倒记时器

2007-07-17 17:06 134 查看
<%@ 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>



转自 http://blog.csdn.net/sibyle/archive/2007/06/11/1647794.aspx

来源 http://www.dynamicdrive.com/dynamicindex6/universalcountdown.htm
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: