1. 程式人生 > >JS實現為控件添加倒計時功能

JS實現為控件添加倒計時功能

設置 .net right ble tro string star js實現 格式化時間

一.概述

在有些報表需求中,需要為控件添加倒計時功能,限制到某一個時間點後能進行一項操作或不能進行某項操作,比如查詢,導出功能等等,又需要人性化地顯示還有多少時間,即倒計時功能,比如下圖中我們限制這個報表在每天10點後才能查詢

技術分享

當倒計時結束的時候,查詢功能可用

技術分享

這種功能如何實現的呢

二.實現思路

主要原理是利用控件的setEnable(true)/setEnable(false)來進行設置控件的可用與不可用狀態,在獲取時間的過程中,需要利用到js中的獲取時間,利用JS的定時器函數setInterval(function(){},time)來進行定時取得倒時時,並判斷倒計時是否結束。

三.實現過程

1、修改模板

以自帶的gettingstarted.cpt模板為例,設置初始化時查詢按鈕不可用,如下圖

技術分享

2、添加倒計時控制功能

為了簡化控制流程,把JS代碼直接寫在查詢按鈕的初始化後事件中,如下圖

技術分享
代碼如下:

1. var h=10;//限制幾點可查詢

2. var m=00;//限制幾分可查詢

3. var s=00;//限制幾秒可查詢

4. //格式化時間

5. function timeToString(a){

6. //小時

7. var s=‘還有‘

8. s+=parseInt(a/3600)+‘時‘;

9. //分

10. s+=parseInt(a % 3600 /60)+‘分‘;

11. //秒

12. s+=parseInt(a % 60)+‘秒可查‘;

13. return s;

14. }

15. var date1=new Date();

16. var date2=new Date();

17. //設置預置可查時間

18. date1.setHours(h);

19. date1.setMinutes(m);

20. date1.setSeconds(s);

21. //比如時間

22. var d=(date1-date2)/1000;

23. //如果初始化時可用,就啟用按鈕

24. if(d<0){

25. this.setValue(‘查詢‘);

26. this.setEnable(true);

27. } else {

28. var btn=this;

29. //顯示倒計時時間

30. btn.setValue(timeToString(d));

31. //設置不可用

32. btn.setEnable(false);

33. //定時器函數

34. setInterval(function(){

35. //重新設置時間

36. date1=new Date();

37. date2=new Date();

38. date1.setHours(h);

39. date1.setMinutes(m);

40. date1.setSeconds(s);

41. //重新當前時間與設定時間的時間差

42. d=(date1-date2)/1000;

43. if(d<0){

44. btn.setValue(‘查詢‘);

45. btn.setEnable(true);

46. } else {

47. btn.setValue(timeToString(d));

48. btn.setEnable(false);

49. }

50. },1000);

51. }

3.預覽

最終效果如上圖.

本文首發CSDN:http://blog.csdn.net/szd_happy/article/details/74295088

JS實現為控件添加倒計時功能