网页存储倒计时与解决网页cookie保存多个相同key问题

短信倒计时多用网页临时存储,这可以保证网页在关闭状态也可记时。

 1 <p class="test_button" id="getcode">获取验证码</p>
 2 
 3 <script type="text/javascript">
 4 //加载页面访问cookie,防止关闭网页
 5 var t=getCookie("codeTime")>0?setCodeTime($("#getcode")):"";
 6 
 7 //短信倒计时事件
 8 var countdown;
 9 function setCodeTime(obj){
10     countdown=getCookie("codeTime");
11     if (countdown == 0) {
12         obj.html("获取验证码"); 
13         clearTimeout(mobRandomTime);
14         delCookie("codeTime");
15         return;
16     } else { 
17         obj.html(countdown + "秒重发"); 
18         countdown--;
19         editCookie("codeTime",countdown,countdown);
20      } 
21     mobRandomTime=setTimeout(function() { setCodeTime(obj) },1000) //每1000毫秒执行一次}
22 
23 //短信发送事件,设定短信间隔
24 function phoneNote(obj,timeInterval){
25     var obj=obj;
26     addCookie("codeTime",timeInterval,timeInterval);
27     setCodeTime(obj);
28 }
29 //触发短信发送
30 $("#getcode").click(function(){
31     var t=getCookie("codeTime")>0?"":phoneNote($("#getcode"),10);
32 })
33 </script>

在当前页状态,每秒获取并修改cookie。

同时Cookie不仅仅有名字和值两个属性,还有域(domain),过期时间(expires),路径(path)等属性。 其中,不同的域、不同的路径下可以存在同样名字的cookie。

 1 //添加cookie
 2 function addCookie(name,value,expireHours){
 3     var cookieString=name+"="+escape(value)+"; path=/";//注意红色话语,这是保证不会出现多个key的,只修改对应路径的key
 4     //判断是否设置过期时间
 5     if(expireHours>0){
 6         var date=new Date();
 7         date.setTime(date.getTime+expireHours*1000);
 8         cookieString=cookieString+"; expire="+date.toGMTString();
 9     }
10     document.cookie=cookieString;
11 }
12 //获取cookie
13 function getCookie(name){
14     var strcookie=document.cookie;
15     var arrcookie=strcookie.split("; ");
16     for(var i=0;i<arrcookie.length;i++){
17     var arr=arrcookie[i].split("=");
18     if(arr[0]==name)return arr[1];
19     }
20     return "";
21 }
22 //修改cookie的值
23 function editCookie(name,value,expiresHours){ 
24     var cookieString=name+"="+escape(value)+"; path=/";//注意红色话语,这是保证不会出现多个key的,只修改对应路径的key
25     if(expiresHours>0){ 
26       var date=new Date(); 
27       date.setTime(date.getTime()+expiresHours*1000); //单位是毫秒
28       cookieString=cookieString+";expires=" + date.toGMTString(); 
29     } 
30       document.cookie=cookieString; 
31 } 
32 //删除cookie
33 function delCookie(name){//删除cookie
34     var exp = new Date();
35     exp.setTime(exp.getTime() - 1);
36     var cval=getCookie(name);
37     if(cval!=null) document.cookie= name + "="+cval+"; path=/;expires="+exp.toGMTString();
38 }

 

posted @ 2017-02-28 16:38  AaronHuang  阅读(2581)  评论(0编辑  收藏  举报