文章詳情頁
javascript - 原生JS實現發送驗證碼計秒
瀏覽:248日期: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. mac里的docker如何命令行開啟呢?2. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?3. nignx - docker內nginx 80端口被占用4. docker容器呢SSH為什么連不通呢?5. 關于docker下的nginx壓力測試6. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題7. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””8. angular.js使用$resource服務把數據存入mongodb的問題。9. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????10. docker-compose 為何找不到配置文件?
排行榜

網公網安備