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

 <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. webpack 配置之入门一

    webpack 是一个现代 Javascript 应用程序的模块打包器(module bundler ),它里面的功能比较多,核心模块可分为模块打包.代码分割与按需加载.这里只简单讲解下 webpac ...

  2. keep-alive用法及(activated,deactivated生命周期)

    <template> <div id="app"> <!-- <img src="./assets/logo.png"> ...

  3. Spring Boot 2.X 实现文件上传(三)

    使用 SpringBoot 项目完成单个.多个文件的上传处理,并将上传的文件保存到指定目录下. 代码演示案例 所有的 HTML 页面文件 index.html <!DOCTYPE html> ...

  4. Android SDK Download

    { https://www.androiddevtools.cn/ }

  5. UML关系类图

    在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization),关联(Association),聚合(Aggregation),组合(Composit ...

  6. Intergalactic Map SPOJ - IM

    传送门 我觉得我写得已经和题解一模一样了,不知道为什么就是过不了..懒得拍了,反正不是很难,不太想浪费时间. 1~2~3的一条路径相当于从2~1的一条路径+2~3的一条路径,点不能重复经过,于是拆点. ...

  7. Windows路径操作API函数学习【转载】

    文章出自https://www.cnblogs.com/MakeView660/p/6644838.html 前言 在VC++开发过程中,经常需要用到一些路径操作,比如拼需要的文件路径,搜索路径中的内 ...

  8. 1.RabbitMQ介绍

    MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们.消息传递指的是程序之间 ...

  9. iOS开发UITouch触摸API简介

    1.UITouch简介 当用户触摸屏幕时,会创建一个UITouch对象: UITouch的作用保存着触摸相关的信息,比如触摸的位置.时间.阶段等: 当从开始到结束,系统会更新UITouch对象,结束时 ...

  10. [14]APUE:API for Mysql

    库:/usr/lib64/libmysqlclient.so.#.#... 头文件:/usr/lib64/mysql/mysql.h 一.建立连接 MYSQL *mysql_init(MYSQL *) ...