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


Posted in Javascript onJuly 04, 2017

一.概述

在有些 报表 需求中,需要为控件添加倒计时功能,限制到某一个时间点后能进行一项操作或不能进行某项操作,比如查询,导出功能等等,又需要人性化地显示还有多少时间,即倒计时功能,比如下图中我们限制这个报表在每天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在控件上添加倒计时功能的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
从sohu弄下来的flash中展示图片的代码
Apr 27 Javascript
理解JavaScript变量作用域更轻松
Oct 25 Javascript
纯javascript实现简单下拉刷新功能
Mar 13 Javascript
javascript拖拽效果延伸学习
Apr 04 Javascript
浅谈bootstrap使用中的一些问题以及解决过程
Oct 18 Javascript
JavaScript实现星星等级评价功能
Mar 22 Javascript
jQuery使用ajax_动力节点Java学院整理
Jul 05 jQuery
vue 2.0项目中如何引入element-ui详解
Sep 06 Javascript
Node.js实现mysql连接池使用事务自动回收连接的方法示例
Feb 03 Javascript
axios 处理 302 状态码的解决方法
Apr 10 Javascript
js使用cookie实现记住用户名功能示例
Jun 13 Javascript
vue中@change兼容问题详解
Oct 25 Javascript
JavaScript异步上传图片文件的实例代码
Jul 04 #Javascript
详解vue-router和vue-cli以及组件之间的传值
Jul 04 #Javascript
详解Angular.js中$http拦截器的介绍及使用
Jul 04 #Javascript
详解vue-cli 脚手架项目-package.json
Jul 04 #Javascript
Angular 2父子组件数据传递之@ViewChild获取子组件详解
Jul 04 #Javascript
详解node如何让一个端口同时支持https与http
Jul 04 #Javascript
Angular 2父子组件之间共享服务通信的实现
Jul 04 #Javascript
You might like
在任意字符集下正常显示网页的方法一
2007/04/01 PHP
PHP5.5和之前的版本empty函数的不同之处
2014/06/13 PHP
php获取汉字拼音首字母的方法
2015/10/21 PHP
php事件驱动化设计详解
2016/11/10 PHP
Yii2设置默认控制器的两种方法
2017/05/19 PHP
页面只能打开一次Cooike如何实现
2012/12/04 Javascript
js老生常谈之this,constructor ,prototype全面解析
2016/04/05 Javascript
适用于手机端的jQuery图片滑块动画
2016/12/09 Javascript
使用vue构建移动应用实战代码
2017/08/02 Javascript
JS实现浏览上传文件的代码
2017/08/23 Javascript
详解vue项目打包后通过百度的BAE发布到网上的流程
2018/03/05 Javascript
JS使用队列对数组排列,基数排序算法示例
2019/03/02 Javascript
JS计算两个数组的交集、差集、并集、补集(多种实现方式)
2019/05/21 Javascript
layui 关闭open弹出框 刷新table表格页面的方法
2019/09/16 Javascript
关于Node.js中频繁修改代码重启服务器的问题
2020/10/15 Javascript
Python中list列表的一些进阶使用方法介绍
2015/08/15 Python
简单谈谈Python中的反转字符串问题
2016/10/24 Python
Python实现JSON反序列化类对象的示例
2018/01/31 Python
python读取一个目录下所有txt里面的内容方法
2018/06/23 Python
Python3 导入上级目录中的模块实例
2019/02/16 Python
python整小时 整天时间戳获取算法示例
2019/02/20 Python
Python print不能立即打印的解决方式
2020/02/19 Python
在Anaconda3下使用清华镜像源安装TensorFlow(CPU版)
2020/04/19 Python
Homestay中文官网:全球寄宿家庭
2018/10/18 全球购物
沃达丰英国有限公司:Vodafone英国
2019/04/16 全球购物
一套中级Java程序员笔试题
2015/01/14 面试题
室内设计实习自我鉴定
2013/09/25 职场文书
工程造价专业大学生自荐信
2013/10/01 职场文书
大学同学聚会邀请函
2014/01/29 职场文书
公司领导九九重阳节发言稿2014
2014/09/25 职场文书
乡镇群众路线教育实践活动整改措施
2014/10/04 职场文书
2014年医德医风工作总结
2014/11/13 职场文书
2015年生产车间工作总结
2015/04/22 职场文书
关于分班的感言
2015/08/04 职场文书
python基于turtle绘制几何图形
2021/06/15 Python
JavaScript执行机制详细介绍
2021/12/06 Javascript