javascript實(shí)現(xiàn)計(jì)時(shí)器的簡(jiǎn)單方法
計(jì)時(shí)器, 在生活當(dāng)中也是用得頻繁的功能, 比如鍛煉身體, 跑步比賽等等相關(guān)的活動(dòng). 我們用Javascript來(lái)完成一個(gè)計(jì)時(shí)器.
計(jì)時(shí)器, 主要就是對(duì)時(shí)間的一個(gè)邏輯處理, 比如60秒等于1分鐘, 60分鐘等于一個(gè)小時(shí), 我們這里只做到小時(shí)的處理. 就這么一個(gè)簡(jiǎn)單的邏輯, 然后動(dòng)態(tài)的顯示在一個(gè)Input里面.
那現(xiàn)在我們來(lái)完成這個(gè)界面
<label>計(jì)時(shí):</label> <input type="text" name="" id="timer"/> <button onclick="pause(this)" id="pause" state="on">暫停</button> <button onclick="restart()">重新開(kāi)始</button>
給標(biāo)簽元素一個(gè)ID是為了獲取其中的標(biāo)簽, 然后加入了兩個(gè)點(diǎn)擊事件, 計(jì)數(shù)器的暫停, 和重新開(kāi)始事件.
首先我們來(lái)完成開(kāi)始計(jì)時(shí)的處理, 開(kāi)始計(jì)時(shí)主要還是是用了setInterval的方法, 其中每隔1秒執(zhí)行一次方法, 這樣我們就可以對(duì)時(shí)間做處理, 就像開(kāi)頭所說(shuō)60秒等于1分鐘..., 所以這里就需要用判斷來(lái)處理, 最后就將其中的得到的秒,分,時(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方法是為了,后面暫停和重新開(kāi)始做處理.
用戶(hù)點(diǎn)擊了暫停, 計(jì)時(shí)器就停止計(jì)時(shí), 用戶(hù)繼續(xù)點(diǎn)擊這個(gè)按鈕, 計(jì)時(shí)器繼續(xù)計(jì)時(shí). 所以這里有一個(gè)狀態(tài)需要控制,這個(gè)狀態(tài)我們給這個(gè)按鈕一個(gè)屬性.
//暫停和繼續(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"); } }
最后我們來(lái)看一下重新開(kāi)始, 重新開(kāi)始事件就更加簡(jiǎn)單了. 將計(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í)的功能.效果如下
希望本文所述對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。
相關(guān)文章
根據(jù)身份證號(hào)自動(dòng)輸出相關(guān)信息(籍貫,出身日期,性別)
為了減少客戶(hù)的在頁(yè)面的輸入,做了這個(gè)效果,他可以根據(jù)用戶(hù)輸入的身份證號(hào)輸出籍貫、出身日期、性別的相關(guān)信息,需要的朋友可以參考下2013-11-11使用layer彈窗提交表單時(shí)判斷表單是否輸入為空的例子
今天小編就為大家分享一篇使用layer彈窗提交表單時(shí)判斷表單是否輸入為空的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09微信小程序通過(guò)點(diǎn)擊事件傳參(data-)的操作示例
微信小程序可以通過(guò)直接寫(xiě) data-index="1" 進(jìn)行數(shù)據(jù)的綁定 ,利用 bindtap 點(diǎn)擊事件執(zhí)行函數(shù)從而獲取到參數(shù)信息,本文給大家介紹微信小程序通過(guò)點(diǎn)擊事件傳參(data-)的操作,感興趣的朋友一起看看吧2023-12-12JavaScript高級(jí)程序設(shè)計(jì) 客戶(hù)端存儲(chǔ)學(xué)習(xí)筆記
JavaScript高級(jí)程序設(shè)計(jì) 客戶(hù)端存儲(chǔ)學(xué)習(xí)筆記,在客戶(hù)端用于存儲(chǔ)會(huì)話(huà)信息2011-09-09bootstrap table實(shí)現(xiàn)橫向合并與縱向合并
這篇文章主要為大家詳細(xì)介紹了bootstrap table實(shí)現(xiàn)橫向合并與縱向合并,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07微信小程序用戶(hù)授權(quán),以及判斷登錄是否過(guò)期的方法
這篇文章主要介紹了微信小程序用戶(hù)授權(quán)及判斷登錄是否過(guò)期,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05JavaScript實(shí)現(xiàn)ASC轉(zhuǎn)漢字及漢字轉(zhuǎn)ASC的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)ASC轉(zhuǎn)漢字及漢字轉(zhuǎn)ASC的方法,涉及JavaScript編碼轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2016-01-01