javaScript同意等待代碼實現心得
更新時間:2011年01月01日 19:18:11 作者:
javaScript功能描述:本程序實現在同意某某協(xié)議頁面對同意按鈕進行十秒鐘的禁用,同時在按鈕的Value顯示倒計時。
正確源程序如下:
<script type="text/javascript">
var lastTime = 3;
function abc() {
var btnReg = document.getElementById("btnReg");
if (!btnReg) { return; }
if (lastTime <= 0) {
btnReg.value = "同意";
btnReg.disabled = "";
clearInterval("TimeId");
}
else {
btnReg.value = "還剩下" + lastTime + "秒";
lastTime--;
}
}
var TimeId = setInterval("abc()", 1000);
</script>
我把第四行的 var btnReg = document.getElementById("btnReg")定義為全局變量btnReg = document.getElementById("btnReg");
并且放到函數abc()之外,程序實現不了功能了。
原因如下:瀏覽器解析Html頁面是從上到下,解析到btnReg = document.getElementById("btnReg")時,id為btnReg的按鈕還沒被解析出來,所以全局變量btnReg的值為為定義,
又因為只執(zhí)行了一次所以程序實現不了功能了,而正確的源程序每隔一秒就去取一次,等到button按鈕解析出來后就可以去到值,程序就可以實現功能了。
復制代碼 代碼如下:
<script type="text/javascript">
var lastTime = 3;
function abc() {
var btnReg = document.getElementById("btnReg");
if (!btnReg) { return; }
if (lastTime <= 0) {
btnReg.value = "同意";
btnReg.disabled = "";
clearInterval("TimeId");
}
else {
btnReg.value = "還剩下" + lastTime + "秒";
lastTime--;
}
}
var TimeId = setInterval("abc()", 1000);
</script>
我把第四行的 var btnReg = document.getElementById("btnReg")定義為全局變量btnReg = document.getElementById("btnReg");
并且放到函數abc()之外,程序實現不了功能了。
原因如下:瀏覽器解析Html頁面是從上到下,解析到btnReg = document.getElementById("btnReg")時,id為btnReg的按鈕還沒被解析出來,所以全局變量btnReg的值為為定義,
又因為只執(zhí)行了一次所以程序實現不了功能了,而正確的源程序每隔一秒就去取一次,等到button按鈕解析出來后就可以去到值,程序就可以實現功能了。
相關文章
JavaScript通過attachEvent和detachEvent方法處理帶參數的函數
通過 attachEvent 和 detachEvent 方法處理帶參數的函數(示例代碼)2010-03-03js和jquery批量綁定事件傳參數一(新豬豬原創(chuàng))
js綁定事件傳參,javascript綁定事件傳參數,jquery綁定事件傳參數2010-06-06