网页存储倒计时与解决网页cookie保存多个相同key问题
短信倒计时多用网页临时存储,这可以保证网页在关闭状态也可记时。
<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问题的更多相关文章
- 第89天:HTML5中 访问历史、全屏和网页存储API
一.访问历史 API 通过history对象实现前进.后退和刷新之类的操作 history新增的两个方法history.replaceState()和history.pushState()方法属于HT ...
- 使用canvas截图网页为图片并解决跨域空白以及模糊问题
前几天给了个需求对浏览器网页进行截图,把网页统计数据图形表等截图保存至用户本地. 首先对于网页截图,我用的是canvas实现,获取你需要截图的模块的div,从而使用canvas对你需要的模块进行截图. ...
- URLRedirector 解决网页上无法访问 google CDN 的问题(fonts、ajax、themes、apis等)
URLRedirector 解决网页上无法访问 google CDN 的问题(fonts.ajax.themes.apis等) 由于某些原因,在访问国外的网站时有时候会特别慢,像 stackoverf ...
- 使用history.back()出现"警告: 网页已过期的解决办法"
原因: 表单提交页面中使用了 session_start 函数.由于我们后退浏览的是缓存页,而该函数会强制当前页面不被缓存. 解决: PHP: 此提示出现在一个POST提交的页面,点到其它页面后,通过 ...
- 利用Readability解决网页正文提取问题
分享: 利用Readability解决网页正文提取问题 做数据抓取和分析的各位亲们, 有没有遇到下面的难题呢? - 如何从各式各样的网页中提取正文!? 虽然可以用SS为各种网站写脚本做解析, 但是 ...
- 解决网页中Waiting (TTFB)数据加载过慢的问题
解决网页中Waiting (TTFB)数据加载过慢的问题 最近做了一个网页,在本地测试良好,数据可以得到很快的反馈,但是当部署到云端Linux上时候,就会出现加载缓慢的问题.本地测试,得到数据大概3s ...
- 本地存储sessionStorage 、 localStorage 、cookie整理
sessionStorage . localStorage .cookie 的区别 sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可 ...
- 浏览器存储localStorage、sessionStorage、cookie
localStorage和sessionStorage浏览器支持IE8+(测试IE8不行): localStorage:用于长久保存整个网站的数据,保存的数据没有过期时间,直到手动去除 session ...
- JS 弹出网页 (不显示地址栏,工具栏) 网页去掉地址栏
JS 弹出网页 (不显示地址栏,工具栏) 网页去掉地址栏 window.open()支持环境: JavaScript1.0+/JScript1.0+/Nav2+/IE3+/Opera3+ 基本语法: ...
随机推荐
- Install .NET Core Runtime on Linux Ubuntu 16.04 x64
原文链接https://www.microsoft.com/net/download/linux-package-manager/ubuntu16-04/runtime-current nstall ...
- 《代码大全2》读书笔记 Week3
<代码大全2>第六.七章 作者在第六章中从抽象数据类型(Abstract Data Type)出发阐释类(class)的概念,给出创建类的原因以及创建高质量的常涉及的设计问题.抽象数据类型 ...
- 标准 I/O (带缓冲)
标准IO中分文本流和二进制流 windows系统中:(1) 二进制流 - 换行符 '\n' (2) 文本流 - 换行符 ‘\r' '\n' linux 系统中:不区分文本流和二进制流:换行符 - ...
- 修改Tomcat的端口号方法
(1).查找conf路径下的server.xml文件,路径如: I: \tomcat6\apache-tomcat-6.0.32\conf\server.xml (2).打开server.xml文 ...
- MapReduce分区数据倾斜
什么是数据倾斜? 数据不可避免的出现离群值,并导致数据倾斜,数据倾斜会显著的拖慢MR的执行速度 常见数据倾斜有以下几类 1.数据频率倾斜 某一个区域的数据量要远远大于其他区域 2.数据大小倾斜 ...
- delphi xe10 获取屏幕截图
//截取屏幕图片 function MakeScaleScreenshot(Sender: TControl): TBitmap; function GetScreenScale: Single; v ...
- delphi JPG转为BMP存入数据库
delphi JPG转为BMP存入数据库 必须在uses中引用JPEG procedure TForm1.BitBtn3Click(Sender: TObject);varjpg:TJPEGim ...
- 分布式项目controller项目中web.xml配置文件的编写
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" " ...
- [HL] 7.5 集训总结
对于某唤做赛区难度的题,我只能是内流满面..拿到题,A神题不可做,B,神题不可做,C,神题不可做...最后yy了一个A的算法...只得了20 TAT.C题骗分似乎有50 ..B题本来想骗分..然后/ ...
- Oracle分页:工作记录
Oracle分页:传入值为List<String> . Mybatis XXXMapper.xml SELECT * FROM ( SELECT ROWNUM rn, t1.cardnum ...