htmlheadscript type="text/javascript"function startTime(){var today=new Date()var h=today.getHours()var m=today.getMinutes()var s=today.getSeconds()// add a zero in front of numbers10m=checkTime(m)s=checkTime(s)document.getElementById('txt').innerHTML=h+":"+m+":"+st=setTimeout('startTime()',500)} function checkTime(i){if (i10) {i="0" + i} return i}/script/head body onload="startTime()"div id="txt"/div/body/html
成都地區(qū)優(yōu)秀IDC服務(wù)器托管提供商(創(chuàng)新互聯(lián)建站).為客戶提供專業(yè)的四川主機(jī)托管,四川各地服務(wù)器托管,四川主機(jī)托管、多線服務(wù)器托管.托管咨詢專線:028-86922220
#html:
input?type="button"?value="啟動"?id="btnStart"?/
input?type="button"?value="復(fù)位"?id="btnReset"?/
label?id="lblTime"0:0:0:0/label
#javascript:
window.onload?=?function?()?{
var?start?=?document.getElementById("btnStart");
var?reset?=?document.getElementById("btnReset");
var?time?=?document.getElementById("lblTime");
var?h?=?0,?m?=?0,?s?=?0,?ms?=?0,?t;
//開始計(jì)時(shí)
start.onclick?=?function?()?{
bvalue?=?start.value;
if?(bvalue?==?"啟動")?{
t?=?window.setInterval(function?()?{
if?(ms?==??100)?{
s?+=?1;
ms?=?0;
}
if?(s?==??60)?{
m?+=?1;
s?=?0;
}
if?(m?==??60)?{
h?+=?1;
m?=?0;
}
time.textContent?=?h?+?":"?+?m?+?":"?+?s?+?":"?+?ms;
ms++;
},?10);
start.value?=?"暫停";
}
else?{
window.clearInterval(t);
start.value?=?"啟動";
}
}
//復(fù)位
reset.onclick?=?function?()?{
window.clearInterval(t);
time.textContent?=?0?+?":"?+?0?+?":"?+?0?+?":"?+?0;
}
}
你用的是什么計(jì)時(shí)器?
setTimeout("function",time) 還是 setInterval("function",time)
參數(shù)是一樣的,function是方法名,time是執(zhí)行間隔的毫秒數(shù)
這2個都是計(jì)時(shí)用的
SetInterval會重復(fù)執(zhí)行,setTimeout不會重復(fù)只執(zhí)行一次。
如果要停止需要執(zhí)行clearTimeout(對象) 清除已設(shè)置的setTimeout對象,clearInterval(對象) 清除已設(shè)置的setInterval對象。
用法大概如下:
var objTimout=window.setTimeout(function,5000);//5000毫秒=5秒,5秒后執(zhí)行function方法,然后退出
window.clearTimeout(objTimout);//清除setTimeout設(shè)置的時(shí)間
或者
var objInterval=window.setInterval(function,5000);//每5秒執(zhí)行一次function方法
window.clearInterval(objInterval);//清除setInterval對象設(shè)置的時(shí)間
希望能幫到你!
//?html
div當(dāng)前時(shí)間為:span?id="timeNow"/span?/div
button?id="timeBegin"計(jì)時(shí)開始/button
button?id="timeEnd"計(jì)時(shí)結(jié)束/button
button?id="timeClear"計(jì)時(shí)清除/button
//?Javascript
script?type="text/javascript"
//定義初始值?計(jì)時(shí)器
var?count?=?0;
var?timer?=?"";
//開始計(jì)時(shí)
function?BeginTime(){
var?beginBtn?=?document.getElementById("timeBegin");
beginBtn.onclick?=?function(){
timer?=?setInterval(function(){
count?++?;
document.getElementById("timeNow").innerHTML?=?count?/?100;
},10)
}
}
//結(jié)束計(jì)時(shí)
function?EndTime(){
var?endBtn?=?document.getElementById("timeEnd");
endBtn.onclick?=?function(){
clearInterval(timer);
}
}
//計(jì)時(shí)清除
function?ClearTime(){
var?clearBtn?=?document.getElementById("timeClear");
clearBtn.onclick?=?function(){
document.getElementById("timeNow").innerHTML?=?"";
}
}
BeginTime();
EndTime();
ClearTime();
/script
//??The?Harder?You?Work,?The?Luckier?You?Will?Be.?(Jensonhui.com)
計(jì)時(shí)器, 在生活當(dāng)中也是用得頻繁的功能, 比如鍛煉身體, 跑步比賽等等相關(guān)的活動. 我們用Javascript來完成一個計(jì)時(shí)器.
計(jì)時(shí)器, 主要就是對時(shí)間的一個邏輯處理, 比如60秒等于1分鐘, 60分鐘等于一個小時(shí), 我們這里只做到小時(shí)的處理. 就這么一個簡單的邏輯, 然后動態(tài)的顯示在一個Input里面.
那現(xiàn)在我們來完成這個界面
label計(jì)時(shí):/label
input type="text" name="" id="timer"/
button onclick="pause(this)" id="pause" state="on"暫停/button
button onclick="restart()"重新開始/button
給標(biāo)簽元素一個ID是為了獲取其中的標(biāo)簽, 然后加入了兩個點(diǎn)擊事件, 計(jì)數(shù)器的暫停, 和重新開始事件.
首先我們來完成開始計(jì)時(shí)的處理, 開始計(jì)時(shí)主要還是是用了setInterval的方法, 其中每隔1秒執(zhí)行一次方法,
這樣我們就可以對時(shí)間做處理, 就像開頭所說60秒等于1分鐘..., 所以這里就需要用判斷來處理, 最后就將其中的得到的秒,分,時(shí)顯示到輸入框里.
var ele_timer = document.getElementById("timer");
var n_sec = 0; //秒
var n_min = 0; //分
var n_hour = 0; //時(shí)
//60秒 === 1分
//60分 === 1小時(shí)
function timer() {
return setInterval(function () {
var str_sec = n_sec;
var str_min = n_min;
var str_hour = n_hour;
if ( n_sec 10) {
str_sec = "0" + n_sec;
}
if ( n_min 10 ) {
str_min = "0" + n_min;
}
if ( n_hour 10 ) {
str_hour = "0" + n_hour;
}
var time = str_hour + ":" + str_min + ":" + str_sec;
ele_timer.value = time;
n_sec++;
if (n_sec 59){
n_sec = 0;
n_min++;
}
if (n_min 59) {
n_sec = 0;
n_hour++;
}
}, 1000);
}
var n_timer = timer();
我們用timer方法包裝setInterval方法是為了,后面暫停和重新開始做處理.
用戶點(diǎn)擊了暫停, 計(jì)時(shí)器就停止計(jì)時(shí), 用戶繼續(xù)點(diǎn)擊這個按鈕, 計(jì)時(shí)器繼續(xù)計(jì)時(shí). 所以這里有一個狀態(tài)需要控制,這個狀態(tài)我們給這個按鈕一個屬性.
//暫停和繼續(xù)
function pause(self) {
var state = self.getAttribute("state");
if (state === "on") {
clearInterval(n_timer);
self.textContent = "繼續(xù)";
self.setAttribute("state", "off");
} else {
n_timer = timer();
self.textContent = "暫停";
self.setAttribute("state", "on");
}
}
最后我們來看一下重新開始, 重新開始事件就更加簡單了. 將計(jì)數(shù)器清0, 然后改變暫停按鈕初始狀態(tài).
function restart() {
clearInterval(n_timer);
n_sec = 0;
n_min = 0;
n_hour = 0;
n_timer = timer();
var ele_pause = document.getElementById("pause");
ele_pause.textContent = "暫停";
ele_pause.setAttribute("state", "on");
}
這樣就完成了計(jì)時(shí)的功能.效果如下