初学JS会遇到的一个案例(发送验证码的倒计时效果)
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>发送验证码的倒计时效果</title>
<script type="text/javascript">
// 总体思路:
// 获取按钮,绑定点击事件,在事件处理函数中先把按钮设置为不可用状态(以防止用户多次点击),接着调用一个函数来实现60s的倒计时(函数内部逻辑可以用分支语句来做)
window.onload=function(){
var send=document.getElementById('send'),//获取按钮
times=60; //设置倒计时的初值
function DownToZero(){
if(times>0){
send.value=times+"s后重试"; //更新按钮的文本
times--; //递减
setTimeOut(DownToZero,1000); //通过定时器再次调用函数本身
}else{
send.value="发送验证码"; //将文本复原
send.disabled = false; //将按钮置为可用
times=60; //将数字还原为初值,以便再次计数
}
}
send.onclick=function(){
// 计时开始
send.disabled = true;
DownToZero();
}
}
</script>
</head>
<body>
<input type="button" id="send" value="发送验证码">
<!-- attention:故意写错一个词,希望你能看出来。(因为自己手写代码曾写错,所以在这里提醒一下大家。)
setTimeOut要改为setTimeout
-->
</body>
</html>
点击查看更多内容
2人点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦