JavaScript在控件上添加倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼
一.概述
在有些 報(bào)表 需求中,需要為控件添加倒計(jì)時(shí)功能,限制到某一個(gè)時(shí)間點(diǎn)后能進(jìn)行一項(xiàng)操作或不能進(jìn)行某項(xiàng)操作,比如查詢,導(dǎo)出功能等等,又需要人性化地顯示還有多少時(shí)間,即倒計(jì)時(shí)功能,比如下圖中我們限制這個(gè)報(bào)表在每天10點(diǎn)后才能查詢
當(dāng)?shù)褂?jì)時(shí)結(jié)束的時(shí)候,查詢功能可用
這種功能如何實(shí)現(xiàn)的呢
二.實(shí)現(xiàn)思路
主要原理是利用控件的setEnable(true)/setEnable(false)
來進(jìn)行設(shè)置控件的可用與不可用狀態(tài),在獲取時(shí)間的過程中,需要利用到JS中的獲取時(shí)間,利用JS的定時(shí)器函數(shù)setInterval(function(){},time)
來進(jìn)行定時(shí)取得倒時(shí)時(shí),并判斷倒計(jì)時(shí)是否結(jié)束。
三 .實(shí)現(xiàn)過程
1、修改模板
以自帶的gettingstarted.cpt模板為例,設(shè)置初始化時(shí)查詢按鈕不可用,如下圖
2、添加倒計(jì)時(shí)控制功能
為了簡化控制流程,把JS代碼直接寫在查詢按鈕的初始化后事件中,如下圖
代碼如下:
var h= 10 ; //限制幾點(diǎn)可查詢 var m= 00 ; //限制幾分可查詢 var s= 00 ; //限制幾秒可查詢 //格式化時(shí)間 function timeToString(a){ //小時(shí) var s= '還有' s+=parseInt(a/ 3600 )+ '時(shí)' ; //分 s+=parseInt(a % 3600 / 60 )+ '分' ; //秒 s+=parseInt(a % 60 )+ '秒可查' ; return s; } var date1= new Date(); var date2= new Date(); //設(shè)置預(yù)置可查時(shí)間 date1.setHours(h); date1.setMinutes(m); date1.setSeconds(s); //比如時(shí)間 var d=(date1-date2)/ 1000 ; //如果初始化時(shí)可用,就啟用按鈕 if (d< 0 ){ this .setValue( '查詢' ); this .setEnable( true ); } else { var btn= this ; //顯示倒計(jì)時(shí)時(shí)間 btn.setValue(timeToString(d)); //設(shè)置不可用 btn.setEnable( false ); //定時(shí)器函數(shù) setInterval(function(){ //重新設(shè)置時(shí)間 date1= new Date(); date2= new Date(); date1.setHours(h); date1.setMinutes(m); date1.setSeconds(s); //重新當(dāng)前時(shí)間與設(shè)定時(shí)間的時(shí)間差 d=(date1-date2)/ 1000 ; if (d< 0 ){ btn.setValue( '查詢' ); btn.setEnable( true ); } else { btn.setValue(timeToString(d)); btn.setEnable( false ); } }, 1000 ); }
以上所述是小編給大家介紹的JavaScript在控件上添加倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- JS實(shí)現(xiàn)用戶注冊時(shí)獲取短信驗(yàn)證碼和倒計(jì)時(shí)功能
- JS實(shí)現(xiàn)表單驗(yàn)證功能(驗(yàn)證手機(jī)號是否存在,驗(yàn)證碼倒計(jì)時(shí))
- js實(shí)現(xiàn)發(fā)送驗(yàn)證碼后的倒計(jì)時(shí)功能
- php+js實(shí)現(xiàn)倒計(jì)時(shí)功能
- js實(shí)現(xiàn)網(wǎng)頁倒計(jì)時(shí)、網(wǎng)站已運(yùn)行時(shí)間功能的代碼3例
- javascript倒計(jì)時(shí)功能實(shí)現(xiàn)代碼
相關(guān)文章
javascript在網(wǎng)頁中實(shí)現(xiàn)讀取剪貼板粘貼截圖功能
這篇文章主要介紹了在網(wǎng)頁中實(shí)現(xiàn)讀取剪貼板粘貼截圖功能,即可以把剪貼板的截圖Ctrl+V粘貼到網(wǎng)頁的一個(gè)輸入框中,例如QQ截圖、旺旺截圖或者其它截圖軟件,需要的朋友可以參考下2014-06-06JavaScript使用享元模式實(shí)現(xiàn)文件上傳優(yōu)化操作示例
這篇文章主要介紹了JavaScript使用享元模式實(shí)現(xiàn)文件上傳優(yōu)化操作,結(jié)合實(shí)例形式分析了javascript基于享元模式進(jìn)行文件上傳優(yōu)化操作的原理、步驟及相關(guān)使用技巧,需要的朋友可以參考下2018-08-08JavaScript實(shí)現(xiàn)敏感信息脫敏的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何使用JavaScript實(shí)現(xiàn)敏感信息脫敏,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04JavaScript使用ul中l(wèi)i標(biāo)簽實(shí)現(xiàn)刪除效果
這篇文章主要為大家詳細(xì)介紹了JavaScript使用ul中l(wèi)i標(biāo)簽實(shí)現(xiàn)刪除效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04淺談javascript的url參數(shù)parse和build函數(shù)
下面小編就為大家?guī)硪黄獪\談javascript的url參數(shù)parse和build函數(shù)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03JavaScript中將一個(gè)值轉(zhuǎn)換為字符串的方法分析[譯]
在JavaScript中,主要有三種方法能讓任意值轉(zhuǎn)換為字符串.本文講解了每種方法以及各自的優(yōu)缺點(diǎn)2012-09-09