国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

javascript實(shí)現(xiàn)計時器的簡單方法

2024-05-06 16:28:49
字體:
供稿:網(wǎng)友
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)計時器的簡單方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
 

計時器, 在生活當(dāng)中也是用得頻繁的功能, 比如鍛煉身體, 跑步比賽等等相關(guān)的活動. 我們用Javascript來完成一個計時器.

計時器, 主要就是對時間的一個邏輯處理, 比如60秒等于1分鐘, 60分鐘等于一個小時, 我們這里只做到小時的處理. 就這么一個簡單的邏輯, 然后動態(tài)的顯示在一個Input里面.

javascript實(shí)現(xiàn)計時器的簡單方法

那現(xiàn)在我們來完成這個界面

<label>計時:</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)擊事件, 計數(shù)器的暫停, 和重新開始事件.

首先我們來完成開始計時的處理, 開始計時主要還是是用了setInterval的方法, 其中每隔1秒執(zhí)行一次方法, 這樣我們就可以對時間做處理, 就像開頭所說60秒等于1分鐘..., 所以這里就需要用判斷來處理, 最后就將其中的得到的秒,分,時顯示到輸入框里.

var ele_timer = document.getElementById("timer");var n_sec = 0; //秒var n_min = 0; //分var n_hour = 0; //時//60秒 === 1分//60分 === 1小時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)擊了暫停, 計時器就停止計時, 用戶繼續(xù)點(diǎn)擊這個按鈕, 計時器繼續(xù)計時. 所以這里有一個狀態(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");  }}

最后我們來看一下重新開始, 重新開始事件就更加簡單了. 將計數(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");}

 

這樣就完成了計時的功能.效果如下

javascript實(shí)現(xiàn)計時器的簡單方法

希望本文所述對大家學(xué)習(xí)javascript程序設(shè)計有所幫助。



注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 方正县| 阿克| 库车县| 乌苏市| 永平县| 方正县| 秦安县| 鄂伦春自治旗| 竹山县| 荥经县| 兰考县| 齐河县| 湘西| 招远市| 皋兰县| 子长县| 嵊泗县| 曲松县| 应城市| 灌阳县| 海阳市| 玉龙| 读书| 西吉县| 竹北市| 永州市| 峡江县| 达日县| 日照市| 如皋市| 屯留县| 新巴尔虎右旗| 蓬莱市| 新巴尔虎右旗| 开阳县| 定西市| 绍兴县| 伊金霍洛旗| 阿合奇县| 衡山县| 柳林县|