English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
В данном примере мы делимся конкретным кодом JS для демонстрации обратного отсчета, который вы можете использовать в качестве примера, подробности см. ниже
Первый способ:Код JavaScript для обратного отсчета с точностью до секунды
HTML код:
<form name="form1"> <div align="center" align="center"> <center>До 2010 года осталось: <input type="textarea" name="left" size="35" style="text-align: center"> </center> </div> </form> <script LANGUAGE="javascript"> startclock() var timerID = null; var timerRunning = false; function showtime() { Today = new Date(); var NowHour = Today.getHours(); var NowMinute = Today.getMinutes(); var NowMonth = Today.getMonth(); var NowDate = Today.getDate(); var NowYear = Today.getYear(); var NowSecond = Today.getSeconds(); if (NowYear <2000) NowYear=1900+NowYear; Today = null; Hourleft = 23 - NowHour Minuteleft = 59 - NowMinute Secondleft = 59 - NowSecond Yearleft = 2009 - NowYear Monthleft = 12 - NowMonth - 1 Dateleft = 31 - NowDate if (Secondleft<0) { Secondleft=60+Secondleft; Minuteleft=Minuteleft-1; } if (Minuteleft<0) { Minuteleft=60+Minuteleft; Hourleft=Hourleft-1; } if (Hourleft<0) { Hourleft=24+Hourleft; Dateleft=Dateleft-1; } if (Dateleft<0) { Dateleft=31+Dateleft; Monthleft=Monthleft-1; } if (Monthleft<0) { Monthleft=12+Monthleft; Yearleft=Yearleft-1; } Temp=Yearleft+' год, '+Monthleft+' месяц, '+Dateleft+' день, '+Hourleft+' час, '+Minuteleft+' минута, '+Secondleft+' секунда' document.form1.left.value=Temp; timerID = setTimeout("showtime()",1000); timerRunning = true; } var timerID = null; var timerRunning = false; function stopclock () { if(timerRunning) clearTimeout(timerID); timerRunning = false; } function startclock () { stopclock(); showtime(); } // --> </script>
Сендово провеления:меневове меневрири
HTML код:
<!--отнике провеления донова провеления меневрири не отнике--> <script language="JavaScript"> <!-- function DigitalTime1() { var deadline= new Date("08/13/2007") // отнике провеления нововенове меневрири var symbol=вемеднове невопровно донова 13 меневрири var now = new Date() var diff = -480 - now.getTimezoneOffset() // по меневове боления меневрири от меневове меневрири var leave = (deadline.getTime() - now.getTime()) + diff*60000 var day = Math.floor(leave / (1000 * 60 * 60 * 24)) var hour = Math.floor(leave / (1000*3600)) - (day * 24) var minute = Math.floor(leave / (1000*60)) - (day * 24 *60) - (hour * 60) var second = Math.floor(leave / (1000)) - (day * 24 *60*60) - (hour * 60 * 60) - (minute*60) var deadline_2= new Date("08/13/2004") // отнике провеления нововенове меневрири var symbol_2=вемеднове невопровно донова 13 меневрири var now_2 = new Date() var diff_2 = -480 - now.getTimezoneOffset() // The time difference between Beijing time and local time var leave_2 = (now_2.getTime() - deadline_2.getTime()) + diff_2 * 60000 var day_2 = Math.floor(leave_2 / (1000 * 60 * 60 * 24)) var hour_2 = Math.floor(leave_2 / (1000 * 3600)) - (day_2 * 24) var minute_2 = Math.floor(leave_2 / (1000 * 60)) - (day_2 * 24 * 60) - (hour_2 * 60) var second_2 = Math.floor(leave_2 / (1000)) - (day_2 * 24 * 60 * 60) - (hour_2 * 60 * 60) - (minute_2 * 60) day=day+1; day_2=day_2+1; if (day>0) // The opening has not started yet { //LiveClock1.innerHTML = "Now " + symbol + " days" LiveClock1.innerHTML = "<font setTimeout("DigitalTime1()",1000) } if (day<0) // The opening has already started { //LiveClock1.innerHTML = "Now it is " + symbol + " away " + day + " days " + hour + " hours " + minute + " minutes " + second + " seconds" LiveClock1.innerHTML = "<font setTimeout("DigitalTime1()",1000) } if (day==0) // The opening is in progress { //LiveClock1.innerHTML = "Now " + symbol + " days" LiveClock1.innerHTML = "<font setTimeout("DigitalTime1()",1000) } if (day<0 && day_2>19) // The end of some sports meeting { //LiveClock1.innerHTML = "Now it is " + symbol + " away " + day + " days " + hour + " hours " + minute + " minutes " + second + " seconds" LiveClock1.innerHTML = "<font setTimeout("DigitalTime1()",1000) } } // --> </script> <!--Countdown Javascript end--> <body onload=DigitalTime1()> <div id= LiveClock1></div> </body>
The third type:Hour countdown
HTML код:
<SCRIPT LANGUAGE="JavaScript"> <!-- var maxtime = 60*60 // one hour, calculated in seconds, adjust by yourself! function CountDown() { if(maxtime>=0){ minutes = Math.floor(maxtime/60); seconds = Math.floor(maxtime%60); msg = "До окончания осталось"+minutes+" минут"+seconds+" секунд"; document.all["timer"].innerHTML=msg; if(maxtime == 5*60) alert('Внимание, осталось 5 минут!'); --maxtime; } else{ clearInterval(timer); alert("Время истекло, завершение!"); } } timer = setInterval("CountDown()",1000); //--> </SCRIPT> <div id="timer" style="color:red"></div>
Четвертый вид:Простой обратный отсчет
HTML код:
<Script Language="JavaScript"> <!-- Начало var timedate= new Date("January 14,2006"); var times="的研究生考试"; var now = new Date(); var date = timedate.getTime() - now.getTime(); var time = Math.floor(date / (1000 * 60 * 60 * 24)); if (time >= 0) ; document.write("<li><font color=#DEDBDE>До 2006 года"+times+"остается: <font color=#ffffff><b>"+time +"</b></font> дней</font></li>"); // Конец --> </Script>
Пятый вид:Самый простой обратный отсчет
HTML код:
<script language="JavaScript" type="text/javascript"> function djs(){ var urodz= new Date("11/12/2008"); var now = new Date(); var num var ile = urodz.getTime() - now.getTime(); var dni = Math.floor(ile / (1000 * 60 * 60 * 24)); if (dni > 1) num=dni+1 else if (dni == 1) num=2 else if (dni == 0) num=1 else num=0 document.write(num) } </script>
До открытия某个 церемонии открытия осталось [<script language="JavaScript" type="text/javascript">djs()</script>] дней
Шестой вариант:JavaScript-счетчик обратного отсчета - использует системное время для самопроверки
В этом случае используется системное время для самопроверки обратного отсчета, что позволяет избежать ручной регулировки и делает обратный отсчет более точным. Код и подробные комментарии приведены ниже:
<span id="clock">00:01:11:00</span> <input id="startB" type="button" value="начать обратный отсчет!" onclick="run()"> <input id="endB" type="button" value="остановить обратный отсчет!" onclick="stop()"> <br> <input id="diff" type="text"> <input id="next" type="text"> <script language="Javascript"> /* Это уведомление должно оставаться неизменным в любое время. countdown.js в. 1.0 Последняя версия доступна по адресу http://blog.csdn.net/yjgx007 Авторское право (c) 2004 Xinyi.Chen. Все права защищены. Создано 30 июля 2004 года Xinyi.Chen. Веб: http://blog.csdn.net/yjgx007 Электронная почта: [email protected] Последнее обновление: 30 июля 2004 года Эта программа является свободным программным обеспечением; Вы можете распространять его и/или изменять его на условиях лицензии GNU General Public License, опубликованная Фондом свободного программного обеспечения; См. GNU General Public License подробнее см. на http://www.gnu.org/copyleft/gpl.html. */ var normalelapse = 100; var nextelapse = normalelapse; var counter; var startTime; var start = clock.innerText; var finish = "00:00:00:00"; var timer = null; // 开始运行 function run() { startB.disabled = true; endB.disabled = false; counter = 0; // 初始化开始时间 startTime = new Date().valueOf(); // nextelapse是定时时间, 初始时为100毫秒 // 注意setInterval函数: 时间逝去nextelapse(毫秒)后, onTimer才开始执行 timer = window.setInterval("onTimer()", nextelapse); } // 停止运行 function stop() { startB.disabled = false; endB.disabled = true; window.clearTimeout(timer); } window.onload = function() { endB.disabled = true; } // 倒计时函数 function onTimer() { if (start == finish) { window.clearInterval(timer); alert("time is up!"); return; } var hms = new String(start).split(":"); var ms = new Number(hms[3]); var s = new Number(hms[2]); var m = new Number(hms[1]); var h = new Number(hms[0]); ms -= 10; if (ms < 0) { ms = 90; s -= 1; if (s < 0) { s = 59; m -= 1; } if (m < 0) { m = 59; h -= 1; } } var ms = ms < 10 ? ("0" + ms) : ms; var ss = s < 10 ? ("0" + s) : s; var sm = m < 10 ? ("0" + m) : m; var sh = h < 10 ? ("0" + h) : h; start = sh + ":" + sm + ":" + ss + ":" + ms; clock.innerText = start; // Удаление предыдущего таймера window.clearInterval(timer); // Система самопроверки времени определяет временной интервал и на этом основании рассчитывается время следующего запуска нового таймера nextelapse counter++; var counterSecs = counter * 100; var elapseSecs = new Date().valueOf() - startTime; var diffSecs = counterSecs - elapseSecs; nextelapse = normalelapse + diffSecs; diff.value = counterSecs + "-" + elapseSecs + "=" + diffSecs; next.value = "nextelapse = " + nextelapse; if (nextelapse < 0) nextelapse = 0; // Запуск нового таймера timer = window.setInterval("onTimer()", nextelapse); } </script>
Добавьте полный обратный отсчет и время, чтобы скопировать и использовать. Результаты выполнения:
День Часы Минуты Секунды 22 января 2013 года 15:44:23 Понедельник
<html> <head> <title>Тест обратного отсчета</title> <script src="http://event.wushuangol.com/ShopClothes/Scripts/jquery-1.4.4.min.js" type="text/javascript"></script> <script language="JavaScript"> $("document").ready(function () { <!-- Время должно быть запущено --> clockon(); }); function clockon() { var now = new Date(); var year = now.getFullYear(); //getFullYear getYear var month = now.getMonth(); var date = now.getDate(); var day = now.getDay(); var hour = now.getHours(); var minu = now.getMinutes(); var sec = now.getSeconds(); var week; month = month + 1; if (month < 10) month = "0" + month; if (date < 10) date = "0" + date; if (hour < 10) hour = "0" + hour; if (minu < 10) minu = "0" + minu; if (sec < 10) sec = "0" + sec; var arr_week = new Array("воскресенье", "понедельник", "вторник", "среда", "четверг", "пятница", "суббота"); week = arr_week[day]; var time = ""; time = year + " год" + month + " месяц" + date + " день " + hour + ":" + minu + ":" + sec + " " + week; $("#bgclock").html(time); var timer = setTimeout("clockon()", 200); } <!-- Скрытый скрипт от старых браузеров var DifferHour = -1 var DifferMinute = -1 var DifferSecond = -1 var Tday1 = new Date("Feb 11, 2013 00:00:00") //**倒计时时间-注意格式 var daysms = 24 * 60 * 60 * 1000 var hoursms = 60 * 60 * 1000 var Secondms = 60 * 1000 var microsecond = 1000 function clock() { var time = new Date() var hour = time.getHours() var minute = time.getMinutes() var second = time.getSeconds() var timevalue = ""+((hour > 12) ? hour-12:hour) timevalue +=((minute < 10) ? ":0":":")+minute timevalue +=((second < 10) ? ":0":":")+second timevalue +=((hour > 12) ? " PM":" AM") var convertHour = DifferHour var convertMinute = DifferMinute var convertSecond = DifferSecond var Diffms = Tday1.getTime() - time.getTime() DifferHour = Math.floor(Diffms / daysms) Diffms -= DifferHour * daysms DifferMinute = Math.floor(Diffms / hoursms) Diffms -= DifferMinute * hoursms DifferSecond = Math.floor(Diffms / Secondms) Diffms -= DifferSecond * Secondms var dSecs = Math.floor(Diffms / microsecond) if(convertHour != DifferHour) document.formnow.dd.value=DifferHour if(convertMinute != DifferMinute) document.formnow.hh.value=DifferMinute if(convertSecond != DifferSecond) document.formnow.mm.value=DifferSecond document.formnow.ss.value=dSecs document.formnow.ss.value=dSecs // document.formnow.Tnow.value= DifferHour DifferMinute + DifferSecond + dSecs setTimeout("clock()",1000) } // Скрыть---> </script> </head> <body onload="clock();return true" > <!-- 显示内容 --> <form name="formnow"> <input name="dd" type="text" style="border:0;" size=2> Дни <input name="hh" type="text" style="border:0;" size=2> Часы <input name="mm" type="text" style="border:0;" size=2> Минуты <input name="ss" type="text" style="border:0;" size=2> Секунды <span id="bgclock" style="float:right;padding-right:10px; padding-top:2px;color:red"></span> </form> Конец таймера! </body> </html>
Вот и все, что у нас есть в этой статье. Надеюсь, это поможет вам в изучении, и希望大家 будут активно поддерживать учебник «Крич!».