用Cookie来实现计时器(发送手机验证码、邮箱)

当我们在一个网站上注册时,要根据手机号码来获取验证码,而验证码中包括一个时间计数器。我们用普通的Js时间时间计数时就会出现当我们刷新页面的时候验证码计数器部消失了。所以这里我们想到了用Js来操作Cookie信息来实现保存时间计数器。具体实现如下代码:


Html中嵌入一个时间计数器

<div class="widget-content" id="demo1">
<span style="white-space:pre">	</span><input type="button" value="获取验证码" onclick="times()">
</div>
       

        Js代码

<script type="text/javascript">
	
	function times(){
		var time = getCookie("time");
		if(time == null){
			time = 60;
		}
		time--;
		setCookie("time", time);
		
		//设置页面样式
		$("#demo1").html(time+"秒后重新获取");
		//过1秒递归调用times()函数
		var funcs = setTimeout("times()", 1000);
		
		if ( time <= 0 ){
			//删除Cookie中的值
			delCookie("time");
			//删除递归调用函数
			clearTimeout(funcs);
			$("#demo1").html("重新发送");
		}
	}
	
	//设计Cookie的值
	function setCookie(name,value){ 
	    var Days = 30; 
	    var exp = new Date(); 
	    exp.setTime(exp.getTime() + Days*24*60*60*1000); 
	    document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString(); 
	}
	
	//获取Cookie的值
	function getCookie(name){ 
	    var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");
	 
	    if(arr=document.cookie.match(reg))
	        return unescape(arr[2]); 
	    else 
	        return null; 
	}
	
	//删除Cookie中的值
	function delCookie(name){ 
	    var exp = new Date(); 
	    exp.setTime(exp.getTime() - 1); 
	    var cval=getCookie(name); 
	    if(cval!=null) 
	        document.cookie= name + "="+cval+";expires="+exp.toGMTString(); 
	}


    


猜你喜欢

转载自blog.csdn.net/a1106900429/article/details/48315949