我想在每次引用页面时递增cookie值,即使页面是从缓存加载的。实现这一目标的“最佳”或最简洁的方法是什么?
答案 0 :(得分:29)
从http://www.quirksmode.org/js/cookies.html#script
被盗function createCookie(name,value,days) {
if (days) {
var date = new Date();
date.setTime(date.getTime()+(days*24*60*60*1000));
var expires = "; expires="+date.toUTCString();
}
else var expires = "";
document.cookie = name+"="+value+expires+"; path=/";
}
function readCookie(name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
while (c.charAt(0)==' ') c = c.substring(1,c.length);
if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
}
return null;
}
function eraseCookie(name) {
createCookie(name,"",-1);
}
使用它:
var oldCount = parseInt(readCookie('hitCount'), 10) || 0;
createCookie('hitCount', oldCount + 1, 7);
如评论中所指出的,您应该转换为int,因为cookie存储并作为字符串返回。使用foo++
或++foo
实际上会为您投射,但确切知道您正在使用的内容更安全:
var x = "5"; // x = "5" (string)
x += 1; // x = "51" (string!)
x += 5; // x = "515" (string!)
++x; // x = 516 (number)
答案 1 :(得分:7)
我见过的大多数旧的cookie处理函数都使用简单的字符串操作来存储检索值,例如this示例,你可以使用其他库,如cookie-js,一个小的 (&lt; 100行)用于cookie访问的实用程序。
我个人在我的项目中使用jQuery,并使用jQuery Cookie Plugin,它非常简单易用:
var cookieName = "increment";
if ($.cookie(cookieName) == null){
$.cookie(cookieName, 1, { expires: 10 });
}else{
var newValue = Number($.cookie(cookieName)) + 1;
$.cookie(cookieName, newValue, { expires: 10 });
}
答案 2 :(得分:0)
最好的方法总是最简单的:
function getCookie(name) {
return (name = (document.cookie + ';').match(new RegExp(name + '=.*;'))) && name[0].split(/=|;/)[1];
}
// the default lifetime is 365 days
function setCookie(name, value, days) {
var e = new Date;
e.setDate(e.getDate() + (days || 365));
document.cookie = name + "=" + value + ';expires=' + e.toUTCString() + ';path=/;domain=.' + document.domain;
}
这些函数期望值是一个简单的字符串,但如果你想要或者可能用它做其他事情,你总是可以JSON.stringify ...