saber 酱的抱枕

Fly me to the moon

08/7
2015
学习

js做的获取验证码倒计时效果



今天想到了验证码倒计时的效果,于是做了一个出来。

发现定时器里面写函数名的话,如果带了括号,函数会瞬间执行多次。

代码如下:

<form action="">
	<input type="text">    <input type="button" id="getyzm" value="获取验证码">
</form>
<script>
	function yzmdjs (id,time) {
		var getyzm=document.getElementById(id);
    	var getyzmYuan=getyzm.value;
    	getyzm.setAttribute("disabled","disabled");
    	time=time;
    	getyzm.value=time+"秒后可重新获取验证码";
    	daojishiT=setTimeout(daojishi(),1000);
    	function daojishi () {
	    	//console.log(time);
    		time--;
    		getyzm.value=time+"秒后可重新获取验证码";
    		if (time==0) {
    			getyzm.value=getyzmYuan;
    			getyzm.removeAttribute("disabled");
    		}else{
    			daojishiT=setTimeout(daojishi,1000);
    		};
    	}	    	
	}
	document.getElementById("getyzm").onclick=function  (argument) {
		//添加发送验证码的操作
		yzmdjs(this.id,10);
	}
</script>

js做的获取验证码倒计时效果

08/27
2014
学习

jq发送验证码倒计时效果

一般是给手机发送验证码的按钮,发送一次之后一定时间内不可再发送,从网上找了一个例子试了试。

首先是html部分,先引入jq,然后主体部分就一个按钮,样式可以忽略

接下来是js部分
[code lang="js decode:true ">
wait就是设置的时间了,有两个地方要改;元素的ID根据情况;两个状态下显示的文字也可以改。基本就这些了。

参考:http://www.ipanta.com/article/show/96.html
(一开始我是直接复制过来放在demo里面试的,点了一次发送之后确实出现了倒计时,但是过了一会儿回来一看,计时到了-460秒了,还没有变回去。看了看发现是这个网页的判断条件存在问题,在重置判断里面加上了倒计时小于等于0的条件,然后就能正常用了~

jq发送验证码倒计时效果