欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生js 秒表實(shí)現(xiàn)代碼

 更新時(shí)間:2012年07月24日 01:05:36   作者:  
使用setTimeout遞歸處理。 在這之中,有一個(gè)很重要的問(wèn)題——延遲,這樣的做法和系統(tǒng)CPU資源有很大關(guān)系,而且函數(shù)的調(diào)用也要耗費(fèi)時(shí)間,最終就導(dǎo)致計(jì)數(shù)的誤差越來(lái)越大
html代碼:
復(fù)制代碼 代碼如下:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<meta charset="gb2312">
<head>
<style type="text/css">
#container {
margin:0 auto;
margin-top:10%;
width:200px;
}
#timer {
border:red double 1px;
width:180px;
height:76px;
line-height:76px;
font-size:32pt;
color:green;
}
input {
width:87px;
}
</style>
</head>
<body onload="init()">
<div id="container">
<div id="timer"></div>
<input type="button" id="ctrl" />
<input type="reset" onclick="init()" />
</div>
</body>
</html>

js代碼:
復(fù)制代碼 代碼如下:

/*
*@author:hyjiacan
*date:15:57 2010-9-5
*name:timer
*/
var ctrl = document.getElementById("ctrl"); //控制按鈕對(duì)象
var timer = document.getElementById("timer"); //時(shí)間顯示對(duì)象
var hour, minute, second; //時(shí),分 ,鈔
var t; //setTimeout方法
//初始化顯示和按鈕
var init = function(){
timer.innerHTML = "00:00:00"; //由于FF不支持使用innerText,故采用innerHTML
hour = minute = second = 0; //初始化顯示
ctrl.setAttribute("value", "開(kāi)始"); //初始化控制按鈕文字
ctrl.setAttribute("onclick", "startit()"); //初始化控制按鈕事件
clearTimeout(t);
}
//開(kāi)始計(jì)時(shí)
function startit(){
t = setTimeout("startit()", 1000); //每隔1秒(1000毫秒)遞歸調(diào)用一次
second++;
if(second>=60){ //判斷秒是否到60, 是則進(jìn)位
second = 0;
minute++;
}
if(minute>=60){ //判斷分是否到60, 是則進(jìn)位
minute = 0;
hour++;
}
timer.innerHTML = j(hour) + ":" + j(minute) + ":" + j(second) ; //更新顯示
//更改按鈕狀態(tài)
ctrl.setAttribute("value", "暫停/停止"); //更改按鈕文字
ctrl.setAttribute("onclick", "pause()"); //更改按鈕觸發(fā)事件
}
//顯示數(shù)字填補(bǔ),即當(dāng)顯示的值為0-9時(shí),在前面填補(bǔ)0;如:1:0:4, 則填補(bǔ)成為 01:00:04
var j = function(arg){
return arg>=10 ? arg : "0" + arg;
}
//暫停計(jì)時(shí)
var pause = function(){
clearTimeout(t);
ctrl.setAttribute("onclick", "startit()");
ctrl.setAttribute("value", "繼續(xù)");
}


使用setTimeout遞歸處理。 在這之中,有一個(gè)很重要的問(wèn)題——延遲,這樣的做法和系統(tǒng)CPU資源有很大關(guān)系,而且函數(shù)的調(diào)用也要耗費(fèi)時(shí)間,最終就導(dǎo)致計(jì)數(shù)的誤差越來(lái)越大。

還有另一個(gè)方法:

在按下開(kāi)始按鈕的時(shí)候,記錄下按下的時(shí)間(毫秒),然后每隔1秒讀取一次當(dāng)前時(shí)間,再用當(dāng)前時(shí)間減去按下時(shí)記下的時(shí)間,算出經(jīng)過(guò)了的時(shí)間。

相關(guān)文章

最新評(píng)論