欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2021年06月22日 09:12:51   投稿:lijiao  
這篇文章主要為大家詳細(xì)介紹了javascript實現(xiàn)計時器的簡單方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

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

那現(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)簽, 然后加入了兩個點擊事件, 計數(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方法是為了,后面暫停和重新開始做處理.
用戶點擊了暫停, 計時器就停止計時, 用戶繼續(xù)點擊這個按鈕, 計時器繼續(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");
}

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

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

相關(guān)文章

  • 根據(jù)身份證號自動輸出相關(guān)信息(籍貫,出身日期,性別)

    根據(jù)身份證號自動輸出相關(guān)信息(籍貫,出身日期,性別)

    為了減少客戶的在頁面的輸入,做了這個效果,他可以根據(jù)用戶輸入的身份證號輸出籍貫、出身日期、性別的相關(guān)信息,需要的朋友可以參考下
    2013-11-11
  • 使用layer彈窗提交表單時判斷表單是否輸入為空的例子

    使用layer彈窗提交表單時判斷表單是否輸入為空的例子

    今天小編就為大家分享一篇使用layer彈窗提交表單時判斷表單是否輸入為空的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 微信小程序通過點擊事件傳參(data-)的操作示例

    微信小程序通過點擊事件傳參(data-)的操作示例

    微信小程序可以通過直接寫 data-index="1" 進(jìn)行數(shù)據(jù)的綁定 ,利用 bindtap 點擊事件執(zhí)行函數(shù)從而獲取到參數(shù)信息,本文給大家介紹微信小程序通過點擊事件傳參(data-)的操作,感興趣的朋友一起看看吧
    2023-12-12
  • 詳解Bootstrap插件

    詳解Bootstrap插件

    這篇文章主要為大家針對Bootstrap插件的相關(guān)資料進(jìn)行了詳細(xì)介紹,Bootstrap 自帶 12 種 jQuery 插件,擴(kuò)展了功能,可以給站點添加更多的互動,感興趣的小伙伴們可以參考一下
    2016-04-04
  • JavaScript高級程序設(shè)計 客戶端存儲學(xué)習(xí)筆記

    JavaScript高級程序設(shè)計 客戶端存儲學(xué)習(xí)筆記

    JavaScript高級程序設(shè)計 客戶端存儲學(xué)習(xí)筆記,在客戶端用于存儲會話信息
    2011-09-09
  • bootstrap table實現(xiàn)橫向合并與縱向合并

    bootstrap table實現(xiàn)橫向合并與縱向合并

    這篇文章主要為大家詳細(xì)介紹了bootstrap table實現(xiàn)橫向合并與縱向合并,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • javascript 數(shù)組使用方法匯總

    javascript 數(shù)組使用方法匯總

    由于javascript是一種無類型語言,所以一個數(shù)組的元素可以具有任意的數(shù)據(jù)類型,同一個數(shù)組的不同元素 可以具有不同的類型,數(shù)組的元素設(shè)置可以包含其他數(shù)組,這樣就可以創(chuàng)建一個復(fù)雜的數(shù)組了.
    2009-12-12
  • 微信小程序用戶授權(quán),以及判斷登錄是否過期的方法

    微信小程序用戶授權(quán),以及判斷登錄是否過期的方法

    這篇文章主要介紹了微信小程序用戶授權(quán)及判斷登錄是否過期,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • javascript表單驗證大全

    javascript表單驗證大全

    JavaScript是用來在數(shù)據(jù)被傳輸?shù)椒?wù)前對html表單中輸入的數(shù)據(jù)進(jìn)行驗證,使用javascript對用戶輸入的信息進(jìn)行驗證是項目必須的,下面小編給大家整理一些比較常用的javascript表單驗證,需要的朋友可以參考下
    2015-08-08
  • JavaScript實現(xiàn)ASC轉(zhuǎn)漢字及漢字轉(zhuǎn)ASC的方法

    JavaScript實現(xiàn)ASC轉(zhuǎn)漢字及漢字轉(zhuǎn)ASC的方法

    這篇文章主要介紹了JavaScript實現(xiàn)ASC轉(zhuǎn)漢字及漢字轉(zhuǎn)ASC的方法,涉及JavaScript編碼轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下
    2016-01-01

最新評論