js實現(xiàn)簡單的秒表
更新時間:2020年01月16日 11:38:18 作者:SSSkyCong
這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)簡單的秒表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了js實現(xiàn)簡單的秒表具體代碼,供大家參考,具體內(nèi)容如下
描述:
實現(xiàn)一個簡單的秒表,點擊啟動按鈕時開始計時,隨后啟動按鈕變?yōu)闀和#?/p>
點擊暫停暫停計時,點擊復(fù)位回到最初始狀態(tài)。
效果:

代碼:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
#showTime
{
width: 300px;
height: 60px;
font-size: 60px;
line-height: 60px;
}
</style>
</head>
<body>
<div>
<div id="showTime">00:00:00</div>
<button id="startBn">啟動</button>
<button id="restBn">復(fù)位</button>
</div>
<script>
//——————
var time,showTime,startBn,restBn,pauseDate;
//布爾開關(guān)
var bool=false;
//暫停的累計時間
var pauseTime=0;
init();
function init() {
showTime=document.getElementById("showTime");
startBn=document.getElementById("startBn");
restBn=document.getElementById("restBn");
startBn.addEventListener("click",clickHandler);//開始按鈕 ~ 暫停按鈕
restBn.addEventListener("click",clickHandler);//復(fù)位按鈕
setInterval(animation,16);
}
//轉(zhuǎn)化時間函數(shù)
function animation() {
if(!bool) return;
//前時間減去上次開啟時間減去暫停累計時間
var times=new Date().getTime()-time-pauseTime;
var minutes=Math.floor(times/60000);//毫秒轉(zhuǎn)化為分鐘
var seconds=Math.floor((times-minutes*60000)/1000);//已知分鐘
將time減去分鐘 除去1000得出 秒
var ms=Math.floor((times-minutes*60000-seconds*1000)/10);//
showTime.innerHTML=
(minutes<10 ? "0" +minutes : minutes)+":"
+(seconds<10 ? "0"+seconds :seconds)+":"
+(ms<10 ? "0"+ms : ms);
}
//點擊時的事件
function clickHandler(e) {
e= e || window.event;
if(this===startBn){
bool=!bool;
if(bool){
this.innerHTML="暫停";
//如果我們上一次暫停時間是空,表示沒有暫停過,因此,直接返回0
//如果上次的暫停時間是有值得,用當(dāng)前毫秒數(shù)減去上次的毫秒數(shù),這樣就會得到暫停時間
pauseTime+=(!pauseDate ? 0 : new Date().getTime()-pauseDate);
if(time) return;
time=new Date().getTime();
return;//是為bool判斷跳出
}
this.innerHTML="啟動";
pauseDate=new Date().getTime();
return;//是為this是否等于startBn判斷跳出
}
startBn.innerHTML="啟動";
pauseTime=0;
pauseDate=null;
bool=false;
time=0;
showTime.innerHTML="00:00:00";
}
</script>
</body>
</html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript中使用document.write向頁面輸出內(nèi)容實例
這篇文章主要介紹了JavaScript中使用document.write向頁面輸出內(nèi)容實例,本文講解了輸出普通文字、帶HTML標(biāo)簽內(nèi)容的方法,需要的朋友可以參考下2014-10-10
JavaScript宏任務(wù)和微任務(wù)區(qū)別介紹
這篇文章主要介紹了JavaScript宏任務(wù)和微任務(wù)區(qū)別介紹,js中的任務(wù),大致分為2類,一類是同步任務(wù),另一類是異步任務(wù)。而異步任務(wù),又分為宏任務(wù)和微任務(wù),這兩個任務(wù)是兩個隊列,所以是先進(jìn)先出的2022-07-07
IE中直接運行顯示當(dāng)前網(wǎng)頁中的圖片 推薦
IE中直接運行顯示當(dāng)前網(wǎng)頁中的圖片 推薦...2006-08-08

