js實(shí)現(xiàn)簡(jiǎn)單的秒表
本文實(shí)例為大家分享了js實(shí)現(xiàn)簡(jiǎn)單的秒表具體代碼,供大家參考,具體內(nèi)容如下
描述:
實(shí)現(xiàn)一個(gè)簡(jiǎn)單的秒表,點(diǎn)擊啟動(dòng)按鈕時(shí)開(kāi)始計(jì)時(shí),隨后啟動(dòng)按鈕變?yōu)闀和#?/p>
點(diǎn)擊暫停暫停計(jì)時(shí),點(diǎn)擊復(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">啟動(dòng)</button> <button id="restBn">復(fù)位</button> </div> <script> //—————— var time,showTime,startBn,restBn,pauseDate; //布爾開(kāi)關(guān) var bool=false; //暫停的累計(jì)時(shí)間 var pauseTime=0; init(); function init() { showTime=document.getElementById("showTime"); startBn=document.getElementById("startBn"); restBn=document.getElementById("restBn"); startBn.addEventListener("click",clickHandler);//開(kāi)始按鈕 ~ 暫停按鈕 restBn.addEventListener("click",clickHandler);//復(fù)位按鈕 setInterval(animation,16); } //轉(zhuǎn)化時(shí)間函數(shù) function animation() { if(!bool) return; //前時(shí)間減去上次開(kāi)啟時(shí)間減去暫停累計(jì)時(shí)間 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); } //點(diǎn)擊時(shí)的事件 function clickHandler(e) { e= e || window.event; if(this===startBn){ bool=!bool; if(bool){ this.innerHTML="暫停"; //如果我們上一次暫停時(shí)間是空,表示沒(méi)有暫停過(guò),因此,直接返回0 //如果上次的暫停時(shí)間是有值得,用當(dāng)前毫秒數(shù)減去上次的毫秒數(shù),這樣就會(huì)得到暫停時(shí)間 pauseTime+=(!pauseDate ? 0 : new Date().getTime()-pauseDate); if(time) return; time=new Date().getTime(); return;//是為bool判斷跳出 } this.innerHTML="啟動(dòng)"; pauseDate=new Date().getTime(); return;//是為this是否等于startBn判斷跳出 } startBn.innerHTML="啟動(dòng)"; pauseTime=0; pauseDate=null; bool=false; time=0; showTime.innerHTML="00:00:00"; } </script> </body> </html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)秒表計(jì)時(shí)器
- js實(shí)現(xiàn)計(jì)時(shí)器秒表功能
- Javascript實(shí)現(xiàn)秒表倒計(jì)時(shí)功能
- javascript 秒表計(jì)時(shí)器實(shí)現(xiàn)代碼
- 原生js實(shí)現(xiàn)秒表計(jì)時(shí)器功能
- javascript實(shí)現(xiàn)秒表計(jì)時(shí)器的制作方法
- js仿iphone秒表功能 計(jì)算平均數(shù)
- javascript設(shè)計(jì)簡(jiǎn)單的秒表計(jì)時(shí)器
- js實(shí)現(xiàn)簡(jiǎn)單秒表走動(dòng)的時(shí)鐘特效
- 原生js 秒表實(shí)現(xiàn)代碼
- 魔方在線秒表javascript版
相關(guān)文章
全面解析JavaScript中apply和call以及bind(推薦)
在javascript中apply、call和bind是三兄弟,很好的搭檔,下面小編給大家全面解析JavaScript中apply和call以及bind的相關(guān)知識(shí),感興趣的朋友一起學(xué)習(xí)吧2016-06-06跟我學(xué)習(xí)javascript的作用域與作用域鏈
跟我學(xué)習(xí)javascript的作用域與作用域鏈,感興趣的小伙伴們可以參考一下2015-11-11JavaScript 產(chǎn)生不重復(fù)的隨機(jī)數(shù)三種實(shí)現(xiàn)思路
在 JavaScript 中,一般產(chǎn)生的隨機(jī)數(shù)會(huì)重復(fù),但是有時(shí)我們需要不重復(fù)的隨機(jī)數(shù),如何實(shí)現(xiàn)?本文給于解決方法,需要的朋友可以參考下2012-12-12javascript中數(shù)組和字符串的方法對(duì)比
下面小編就為大家?guī)?lái)一篇javascript中數(shù)組和字符串的方法對(duì)比。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07JS實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)鏈接的幾種方式匯總
這篇文章主要介紹了JS實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)鏈接的幾種方式,簡(jiǎn)單總結(jié)了幾種頁(yè)面跳轉(zhuǎn)功能的實(shí)現(xiàn),有使用js跳轉(zhuǎn)頁(yè)面,返回上一次預(yù)覽界面及button按鈕添加事件跳轉(zhuǎn),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2024-01-01js實(shí)現(xiàn)簡(jiǎn)單的星級(jí)選擇器提交效果適用于評(píng)論等
星級(jí)選擇器在網(wǎng)上會(huì)搜到很多類(lèi)似的代碼,不過(guò)實(shí)現(xiàn)起來(lái)相對(duì)比較復(fù)雜,在本文將為大家介紹的是使用js簡(jiǎn)單的實(shí)現(xiàn)下,感興趣的朋友不要錯(cuò)過(guò)2013-10-10