欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JavaScript在控件上添加倒计时功能的实现代码

程序员文章站 2023-02-25 14:07:02
一.概述 在有些 报表 需求中,需要为控件添加倒计时功能,限制到某一个时间点后能进行一项操作或不能进行某项操作,比如查询,导出功能等等,又需要人性化地显示还有多少时间,即...

一.概述

在有些 报表 需求中,需要为控件添加倒计时功能,限制到某一个时间点后能进行一项操作或不能进行某项操作,比如查询,导出功能等等,又需要人性化地显示还有多少时间,即倒计时功能,比如下图中我们限制这个报表在每天10点后才能查询 

JavaScript在控件上添加倒计时功能的实现代码

JavaScript在控件上添加倒计时功能的实现代码

当倒计时结束的时候,查询功能可用 

JavaScript在控件上添加倒计时功能的实现代码

这种功能如何实现的呢

二.实现思路

主要原理是利用控件的setenable(true)/setenable(false)来进行设置控件的可用与不可用状态,在获取时间的过程中,需要利用到js中的获取时间,利用js的定时器函数setinterval(function(){},time)来进行定时取得倒时时,并判断倒计时是否结束。

三 .实现过程

1、修改模板

以自带的gettingstarted.cpt模板为例,设置初始化时查询按钮不可用,如下图  

JavaScript在控件上添加倒计时功能的实现代码

2、添加倒计时控制功能

为了简化控制流程,把js代码直接写在查询按钮的初始化后事件中,如下图

JavaScript在控件上添加倒计时功能的实现代码

代码如下:

 var h= 10 ; //限制几点可查询 
 var m= 00 ; //限制几分可查询 
 var s= 00 ; //限制几秒可查询 
 //格式化时间 
 function timetostring(a){ 
  //小时 
  var s= '还有' 
  s+=parseint(a/ 3600 )+ '时' ; 
  //分 
  s+=parseint(a % 3600 / 60 )+ '分' ; 
  //秒 
  s+=parseint(a % 60 )+ '秒可查' ; 
  return s; 
 } 
 var date1= new date(); 
 var date2= new date(); 
 //设置预置可查时间 
 date1.sethours(h); 
 date1.setminutes(m); 
 date1.setseconds(s); 
 //比如时间 
 var d=(date1-date2)/ 1000 ; 
 //如果初始化时可用,就启用按钮 
 if (d< 0 ){ 
  this .setvalue( '查询' ); 
  this .setenable( true ); 
 } else {  
  var btn= this ;  
  //显示倒计时时间 
  btn.setvalue(timetostring(d)); 
  //设置不可用 
  btn.setenable( false );  
  //定时器函数 
  setinterval(function(){ 
   //重新设置时间 
   date1= new date();  
   date2= new date(); 
   date1.sethours(h); 
   date1.setminutes(m); 
   date1.setseconds(s); 
   //重新当前时间与设定时间的时间差 
   d=(date1-date2)/ 1000 ; 
   if (d< 0 ){ 
   btn.setvalue( '查询' ); 
   btn.setenable( true ); 
   } else {  
   btn.setvalue(timetostring(d)); 
   btn.setenable( false );  
   } 
  }, 1000 ); 
 } 

以上所述是小编给大家介绍的javascript在控件上添加倒计时功能的实现代码,希望对大家有所帮助