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

 <p class="test_button" id="getcode">获取验证码</p>

 <script type="text/javascript">
//加载页面访问cookie,防止关闭网页
var t=getCookie("codeTime")>0?setCodeTime($("#getcode")):""; //短信倒计时事件
var countdown;
function setCodeTime(obj){
countdown=getCookie("codeTime");
if (countdown == 0) {
obj.html("获取验证码");
clearTimeout(mobRandomTime);
delCookie("codeTime");
return;
} else {
obj.html(countdown + "秒重发");
countdown--;
editCookie("codeTime",countdown,countdown);
}
mobRandomTime=setTimeout(function() { setCodeTime(obj) },1000) //每1000毫秒执行一次} //短信发送事件,设定短信间隔
function phoneNote(obj,timeInterval){
var obj=obj;
addCookie("codeTime",timeInterval,timeInterval);
setCodeTime(obj);
}
//触发短信发送
$("#getcode").click(function(){
var t=getCookie("codeTime")>0?"":phoneNote($("#getcode"),10);
})
</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 }

网页存储倒计时与解决网页cookie保存多个相同key问题的更多相关文章

  1. 第89天:HTML5中 访问历史、全屏和网页存储API

    一.访问历史 API 通过history对象实现前进.后退和刷新之类的操作 history新增的两个方法history.replaceState()和history.pushState()方法属于HT ...

  2. 使用canvas截图网页为图片并解决跨域空白以及模糊问题

    前几天给了个需求对浏览器网页进行截图,把网页统计数据图形表等截图保存至用户本地. 首先对于网页截图,我用的是canvas实现,获取你需要截图的模块的div,从而使用canvas对你需要的模块进行截图. ...

  3. URLRedirector 解决网页上无法访问 google CDN 的问题(fonts、ajax、themes、apis等)

    URLRedirector 解决网页上无法访问 google CDN 的问题(fonts.ajax.themes.apis等) 由于某些原因,在访问国外的网站时有时候会特别慢,像 stackoverf ...

  4. 使用history.back()出现"警告: 网页已过期的解决办法"

    原因: 表单提交页面中使用了 session_start 函数.由于我们后退浏览的是缓存页,而该函数会强制当前页面不被缓存. 解决: PHP: 此提示出现在一个POST提交的页面,点到其它页面后,通过 ...

  5. 利用Readability解决网页正文提取问题

    分享: 利用Readability解决网页正文提取问题   做数据抓取和分析的各位亲们, 有没有遇到下面的难题呢? - 如何从各式各样的网页中提取正文!? 虽然可以用SS为各种网站写脚本做解析, 但是 ...

  6. 解决网页中Waiting (TTFB)数据加载过慢的问题

    解决网页中Waiting (TTFB)数据加载过慢的问题 最近做了一个网页,在本地测试良好,数据可以得到很快的反馈,但是当部署到云端Linux上时候,就会出现加载缓慢的问题.本地测试,得到数据大概3s ...

  7. 本地存储sessionStorage 、 localStorage 、cookie整理

    sessionStorage . localStorage .cookie 的区别 sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可 ...

  8. 浏览器存储localStorage、sessionStorage、cookie

    localStorage和sessionStorage浏览器支持IE8+(测试IE8不行): localStorage:用于长久保存整个网站的数据,保存的数据没有过期时间,直到手动去除 session ...

  9. JS 弹出网页 (不显示地址栏,工具栏) 网页去掉地址栏

    JS 弹出网页 (不显示地址栏,工具栏) 网页去掉地址栏 window.open()支持环境: JavaScript1.0+/JScript1.0+/Nav2+/IE3+/Opera3+ 基本语法: ...

随机推荐

  1. transport error 202: bind failed: Address already in use

    background: I have terminated some test debugger without properly saying goodbye. the JDWP didn't cl ...

  2. 2018-2-13-win10-edge扩展

    title author date CreateTime categories win10 edge扩展 lindexi 2018-2-13 17:23:3 +0800 2018-2-13 17:23 ...

  3. 编写Storm程序

  4. cmake 支持-lpthread

    set(CMAKE_BUILD_TYPE "Release") if( CMAKE_BUILD_TYPE STREQUAL "Debug" )    set(C ...

  5. 普通浏览器实现点击打开微信app

    给予点击事件,然后调用以下方法即可(我这用的是jq的点击): $(function() { Cz.Alert().success({text: '请返回公众号查看充值结果'}); $(".a ...

  6. 更强大的实时数仓构建能力!分析型数据库PostgreSQL 6.0新特性解读

    阿里云 AnalyticDB for PostgreSQL 为采用MPP架构的分布式集群数据库,完备支持SQL 2003,部分兼容Oracle语法,支持PL/SQL存储过程,触发器,支持标准数据库事务 ...

  7. kafka拦截器原理|案例实操

    拦截器原理 Producer拦截器(interceptor)是在Kafka 0.10版本被引入的,主要用于实现clients端的定制化控制逻辑. 对于producer而言,interceptor使得用 ...

  8. centos7 开机自动执行shell脚本

    centos7 开机自动执行shell脚本 90十80 关注 2018.12.23 09:37 字数 309 阅读 485评论 0喜欢 0 自己新建一个脚本,如centnet-service.sh 经 ...

  9. iOS 点击Application icon加载推送通知Data

    今天做APNS远程推送通知遇到了一个问题,就是手机接收到通知的时候,如果马上点击通知的 alert view时候,系统马上唤醒你的Application,通知或调用你的didReceiveLocalN ...

  10. /lib/libmysqlcppconn.so: undefined reference to `mysql_stmt_execute@libmysqlclient_18' 解决方法

    sudo apt-get install libmysqlcppconn-dev