文章詳情頁
javascript - 原生JS實現發送驗證碼計秒
瀏覽:129日期:2023-03-28 11:50:01
問題描述
現在有個問題就如題所示,我想有一個登錄頁面,但是是基于遙控器的。綁定手機時需要向手機發送驗證碼,隨后按鈕的label就要隨著時間減少 60s 50s ... 0s 等 在計秒的過程中,我可能還會上下左右操作。
問題是這樣,稍微了解了下 js 是單線程運行 我計秒這個 動作 和我計秒的同時進行上下左右切換焦點并行,在我理解是2個線程操作。所以 小弟不得其解,怎么去實現呢? 求高人指點。
問題解答
回答1:開一個 setInterval 跑完60秒自動解除button的disabled
跑的過程中時間累減
比如
//偽代碼、思路是這樣var i = 60;var interval;interval = setInterval(function(){ document.getElementById('testBtn').innerHTML(i+’s’) i = i-1 if(i<=0){clearInterval(interval)//解除你的btn不可點擊 }},1000)回答2:
定時器是異步執行的,定時是由另一個工作線程來完成的,對主線程不會有影響。當定時器時間到達后,會把要執行的回調函數放到任務隊列里,并由主線程來調用回調函數。
所以在主線程上的操作不會影響定時器。
回答3:不用關心線程問題 setInterval可以
標簽:
JavaScript
相關文章:
1. list - python 求助2. linux - Ubuntu下編譯Vim8(+python)無數次編譯失敗3. python - TypeError: tryMsgcode() takes exactly 2 arguments (0 given)4. javascript - react,獲取radio的值出錯5. css - 移動端 line-height安卓錯位,蘋果機正常用,縮放解決了,可是又出來了占位的問題6. extra沒有加載出來7. javascript - 彈出一個子窗口,操作之后關閉,主窗口會得到相應的響應,例如網站的某些登錄界面,django后臺的管理等,這是怎么實現的呢?8. 環境搭建 - anaconda 創建python2.7環境中打開編譯器確是3.6版本9. mysql replace 死鎖10. 求救一下,用新版的phpstudy,數據庫過段時間會消失是什么情況?
排行榜
