时间:2021-05-26
正确源程序如下:
复制代码 代码如下:
<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的值为为定义,
又因为只执行了一次所以程序实现不了功能了,而正确的源程序每隔一秒就去取一次,等到button按钮解析出来后就可以去到值,程序就可以实现功能了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Javascript的特点是异步,Javascript不能等待,如果你实现某件需要等待的事情,你不能停在那里一直等待结果回来,相反,底线是使用回调callbac
要实现类似功能,用JS就可以,实现方法如下:一、javascript函数实现:实例1:复制代码代码如下://JavaScript函数:varminute=100
复制代码代码如下: 用Javascript实现锚点(Anchor)间平滑跳转 //说明:用Javascript实现锚点(Anchor)间平滑跳转
很多的时候用户需要等待你“臃肿”的Javascript代码处理完成(Web2.0的特色)。期间或许加入一个类似于进度条的东西让用户有点“安慰”。这个东西实现起来
下面代码用JS实现了程序的暂停与继续复制代码代码如下:/*Javascript中暂停功能的实现Javascript本身没有暂停功能(sleep不能使用)同时vb