JavaScript在控件上添加倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼
一.概述
在有些 報(bào)表 需求中,需要為控件添加倒計(jì)時(shí)功能,限制到某一個(gè)時(shí)間點(diǎn)后能進(jìn)行一項(xiàng)操作或不能進(jìn)行某項(xiàng)操作,比如查詢(xún),導(dǎo)出功能等等,又需要人性化地顯示還有多少時(shí)間,即倒計(jì)時(shí)功能,比如下圖中我們限制這個(gè)報(bào)表在每天10點(diǎn)后才能查詢(xún)
當(dāng)?shù)褂?jì)時(shí)結(jié)束的時(shí)候,查詢(xún)功能可用
這種功能如何實(shí)現(xiàn)的呢
二.實(shí)現(xiàn)思路
主要原理是利用控件的setEnable(true)/setEnable(false)
來(lái)進(jìn)行設(shè)置控件的可用與不可用狀態(tài),在獲取時(shí)間的過(guò)程中,需要利用到JS中的獲取時(shí)間,利用JS的定時(shí)器函數(shù)setInterval(function(){},time)
來(lái)進(jìn)行定時(shí)取得倒時(shí)時(shí),并判斷倒計(jì)時(shí)是否結(jié)束。
三 .實(shí)現(xiàn)過(guò)程
1、修改模板
以自帶的gettingstarted.cpt模板為例,設(shè)置初始化時(shí)查詢(xún)按鈕不可用,如下圖
2、添加倒計(jì)時(shí)控制功能
為了簡(jiǎn)化控制流程,把JS代碼直接寫(xiě)在查詢(xún)按鈕的初始化后事件中,如下圖
代碼如下:
var h= 10 ; //限制幾點(diǎn)可查詢(xún) var m= 00 ; //限制幾分可查詢(xún) var s= 00 ; //限制幾秒可查詢(xún) //格式化時(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( '查詢(xún)' ); 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( '查詢(xún)' ); btn.setEnable( true ); } else { btn.setValue(timeToString(d)); btn.setEnable( false ); } }, 1000 ); }
以上所述是小編給大家介紹的JavaScript在控件上添加倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- JS實(shí)現(xiàn)用戶(hù)注冊(cè)時(shí)獲取短信驗(yàn)證碼和倒計(jì)時(shí)功能
- JS實(shí)現(xiàn)表單驗(yàn)證功能(驗(yàn)證手機(jī)號(hào)是否存在,驗(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)頁(yè)倒計(jì)時(shí)、網(wǎng)站已運(yùn)行時(shí)間功能的代碼3例
- javascript倒計(jì)時(shí)功能實(shí)現(xiàn)代碼
相關(guān)文章
javascript在網(wǎng)頁(yè)中實(shí)現(xiàn)讀取剪貼板粘貼截圖功能
這篇文章主要介紹了在網(wǎng)頁(yè)中實(shí)現(xiàn)讀取剪貼板粘貼截圖功能,即可以把剪貼板的截圖Ctrl+V粘貼到網(wǎng)頁(yè)的一個(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 頁(yè)面只自動(dòng)刷新一次
記得meta標(biāo)簽當(dāng)中有一個(gè)refresh的功能嗎?這是讓瀏覽的頁(yè)面刷新并可以轉(zhuǎn)到相應(yīng)的頁(yè)面,如果刷新本頁(yè)的話(huà)就會(huì)造成重復(fù)的刷新,現(xiàn)在我們就試試用腳本來(lái)實(shí)現(xiàn)只讓頁(yè)面刷新一次.2009-07-07JavaScript實(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ī)?lái)一篇淺談javascript的url參數(shù)parse和build函數(shù)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03js實(shí)現(xiàn)鍵盤(pán)自動(dòng)打字效果
本文主要介紹了基于jQuery實(shí)現(xiàn)的簡(jiǎn)單版鍵盤(pán)自動(dòng)打字效果,具有很好的參考價(jià)值,下面就跟著小編一起來(lái)看下吧2016-12-12JavaScript中將一個(gè)值轉(zhuǎn)換為字符串的方法分析[譯]
在JavaScript中,主要有三種方法能讓任意值轉(zhuǎn)換為字符串.本文講解了每種方法以及各自的優(yōu)缺點(diǎn)2012-09-09