麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

javascript實現的簡單計時器

2024-05-06 16:23:26
字體:
來源:轉載
供稿:網友

計時器提供了一 個可以將代碼片段異步延時執行的能力,javascript生來是單線程的(在一定時間范圍內僅一部分js代碼能運行),計時器為我們提供了一種避開這種 限制的方法,從而開辟了另一條執行代碼的蹊徑。

最近寫了很多微信端的互動小游戲,比如下雪花 限時點擊 贏取獎品,限時拼圖,限時答題等,都是些限時‘游戲'(其實算不上游戲,頂多算是具有一點娛樂性的小互動而已)

上面出現了4個限時,對,沒錯,這里記錄的就是最近寫的 ‘計時器' ...

恩 , 計時器 就一個setInterval 或 setTimeout 即可實現 ,代碼不會超過十行!

但是不防抱著沒事找事的心態,來寫個能復用的計時器

1.能倒計時 也能順計時

2.復位、暫停、停止,啟動功能

 

 
  1. //計時器 
  2. window.timer = (function(){ 
  3. function mod(opt){ 
  4. //可配置參數 都帶有默認值 
  5. //必選參數 
  6. this.ele = typeof(opt.ele)=='string'?document.getElementById(opt.ele):opt.ele;//元素 
  7. //可選參數 
  8. this.startT = opt.startT||0;//時間基數 
  9. this.endT = opt.endT=='undefined'?24*60*60:opt.endT;//結束時間 默認為一天 
  10. this.setStr = opt.setStr||null;//字符串拼接 
  11. this.countdown = opt.countdown||false;//倒計時 
  12. this.step = opt.step||1000; 
  13. //不可配置參數 
  14. this.timeV = this.startT;//當前時間 
  15. this.startB = false;//是否啟動了計時 
  16. this.pauseB = false;//是否暫停 
  17. this.init(); 
  18. mod.prototype = { 
  19. constructor : 'timer'
  20. init : function(){ 
  21. this.ele.innerHTML = this.setStr(this.timeV); 
  22. }, 
  23. start : function(){ 
  24. if(this.pauseB==true||this.startB == true){ 
  25. this.pauseB = false
  26. return
  27. if(this.countdown==false&&this.endT<=this.cardinalNum){ 
  28. return false
  29. }else if(this.countdown==true&&this.endT>=this.startT){ 
  30. return false
  31. this.startB = true
  32. var v = this.startT, 
  33. this_ = this
  34. anim = null
  35. anim = setInterval(function(){ 
  36. if(this_.startB==false||v==this_.endT){clearInterval(anim);return false
  37. if(this_.pauseB==true)return
  38. this_.timeV = this_.countdown?--v:++v; 
  39. this_.ele.innerHTML = this_.setStr(this_.timeV); 
  40. },this_.step); 
  41. }, 
  42. reset : function(){ 
  43. this.startB = false
  44. this.timeV = this.startT; 
  45. this.ele.innerHTML = this.setStr(this.timeV); 
  46. }, 
  47. pause : function(){ 
  48. if(this.startB == true)this.pauseB = true
  49. }, 
  50. stop : function(){ 
  51. this.startB = false
  52. return mod; 
  53. })();  

調用方式:

 

 
  1. var timerO_1 = new timer({ 
  2. ele : 'BOX1'
  3. startT : 0, 
  4. endT : 15, 
  5. setStr : function(num){ 
  6. return num+'s'
  7. }); 
  8. var timerO_2 = new timer({ 
  9. ele : 'BOX2'
  10. startT : 30, 
  11. endT : 0, 
  12. countdown : true
  13. step : 500, 
  14. setStr : function(num){ 
  15. return num+'s'
  16. }); 

這里傳入的方法 setStr是計數器計算的當前時間寫入ele前的字符串處理

countdown是否為倒計時 默認為順計時

可以通過 timerO.timeV 來獲取當前時間

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 久久久www成人免费精品 | 亚洲福利在线视频 | 精品久久一区二区三区 | 欧美日韩1区2区3区 黄片毛片一级 | 激情大乳女做爰办公室韩国 | 国产精品成人av片免费看最爱 | 在线播放亚洲 | 精品国产一区二区三区四区阿崩 | a免费视频 | 一级视频片| 欧美一级性 | 国产一区免费 | 成人在线网站 | 法国极品成人h版 | 久草影音| 国产乱xxxx| 国产成人在线网址 | 国产1区视频 | 麻豆传传媒久久久爱 | 黄在线看 | 国产精品成人免费一区久久羞羞 | 欧美日韩免费一区 | 国产一级毛片高清视频 | 成人网在线观看 | 久久影片| 久久亚洲精品久久国产一区二区 | 99最新地址 | 国产精品jk白丝蜜臀av软件 | 欧美精品一区二区三区在线播放 | 亚洲午夜国产 | 国产人成免费爽爽爽视频 | 欧美亚洲一级 | 国产成人强伦免费视频网站 | 国产在线精品一区二区不卡 | 久久久久久久免费精品 | 精品国产99久久久久久宅男i | 国产精品伦视频看免费三 | 国产一级aaa全黄毛片 | 久久久久久久久成人 | 日本在线视| 国产精品成人免费一区久久羞羞 |