javascript實現計時器的簡單方法,javascript計時器

來源:互聯網
上載者:User

javascript實現計時器的簡單方法,javascript計時器

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

計時器, 主要就是對時間的一個邏輯處理, 比如60秒等於1分鐘, 60分鐘等於一個小時, 我們這裡只做到小時的處理. 就這麼一個簡單的邏輯, 然後動態顯示在一個Input裡面.


那現在我們來完成這個介面

<label>計時:</label> <input type="text" name="" id="timer"/> <button onclick="pause(this)" id="pause" state="on">暫停</button><button onclick="restart()">重新開始</button>

給標籤元素一個ID是為了擷取其中的標籤, 然後加入了兩個點擊事件, 計數器的暫停, 和重新開始事件.

首先我們來完成開始計時的處理, 開始計時主要還是是用了setInterval的方法, 其中每隔1秒執行一次方法, 這樣我們就可以對時間做處理, 就像開頭所說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方法是為了,後面暫停和重新開始做處理.
使用者點擊了暫停, 計時器就停止計時, 使用者繼續點擊這個按鈕, 計時器繼續計時. 所以這裡有一個狀態需要控制,這個狀態我們給這個按鈕一個屬性.

//暫停和繼續function pause(self) {  var state = self.getAttribute("state");  if (state === "on") {   clearInterval(n_timer);   self.textContent = "繼續";   self.setAttribute("state", "off");  } else {   n_timer = timer();   self.textContent = "暫停";   self.setAttribute("state", "on");  }}

最後我們來看一下重新開始, 重新開始事件就更加簡單了. 將計數器清0, 然後改變暫停按鈕初始狀態.

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程式設計有所協助。

您可能感興趣的文章:
  • VB倒計時器和JS目前時間
  • JS 頁面計時器範例程式碼
  • javascript計時器事件使用詳解
  • Node.js中使用計時器定時執行函數詳解
  • JavaScript分秒倒計時器實現方法
  • JavaScript計時器樣本分析
  • javascript計時器詳解
  • javascript實現的簡單計時器
  • javascript設計簡單的秒錶計時器

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.