使用 JavaScript 设置、读取和写入 Cookie
Setting, Reading and Writing Cookie with JavaScript
在这个例子中,我将通过提示询问用户的名字,然后在输入后使用cookie写给div,"欢迎,savedCookie!",然后每次他们在到期前访问页面。
我让浏览器显示一个提示,询问我的名字,然后它写给div 作为"欢迎,未定义!我不知道为什么会收到错误。
//Setting cookie for Users Name
function set_it() {
var userName = prompt("Please Enter Your Name", ""),
thetext = "name=" + userName,
expdate = ";expires=Mon, 27 Mar 2017 13:00:00 UTC",
newtext = encodeURIComponent(thetext);
newtext += expdate;
document.cookie = newtext;
}
//Reading & Writing cookie
function read_it() {
var rawCookie = document.cookie;
bakedCookie = decodeURIComponent(rawCookie);
yumCookie = bakedCookie.split("=");
document.getElementById("greeting").innerHTML = "<p>Welcome, " + yumCookie[1] + "!</p>";
}
if (document.cookie) {
read_it();
} else {
set_it();
read_it();
}
<!DOCTYPE html>
<html>
<head>
<title>Page Title</title>
</head>
<body>
<div id="greeting">
<script src="prjs13_2.js"></script>
</div>
</body>
</html>
尝试在控制台中运行您唯一的此代码,看看您得到了什么-
var userName = prompt("Please Enter Your Name", ""),
thetext = "name=" + userName,
expdate = ";expires=Mon, 27 Mar 2017 13:00:00 UTC",
newtext = encodeURIComponent(thetext);
newtext += expdate;
document.cookie = newtext;
我为"大卫"这个名字做了这件事,我得到了这个——
name%3Ddavid;expires=星期一, 27 Mar 2017 13:00:00 UTC"
当您设置 cookie 时,您的名称属性无效。试试这段代码(没有编码URIComponent和;而不是逗号)-
var userName = prompt("Please Enter Your Name", "");
var thetext = "name=" + userName;
var expdate = ";expires=Mon, 27 Mar 2017 13:00:00 UTC";
var newtext = thetext;
document.cookie = newtext;
您可以使用
以下函数来获取/设置 cookie:
function setCookie(cname, cvalue, exdays) {
var d = new Date();
d.setTime(d.getTime() + (exdays*24*60*60*1000));
var expires = "expires="+d.toUTCString();
document.cookie = cname + "=" + cvalue + "; " + expires;
}
function getCookie(cname) {
var name = cname + "=";
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);
}
if (c.indexOf(name) == 0) {
return c.substring(name.length, c.length);
}
}
return "";
}
function checkCookie() {
var user = getCookie("username");
if (user != "") {
alert("Welcome again " + user);
} else {
user = prompt("Please enter your name:", "");
if (user != "" && user != null) {
setCookie("username", user, 365);
}
}
}
这里有一些小提琴的例子:小提琴
相关文章:
- 无法在基于Cordova的应用程序中读取Set Cookie标头
- MVC C#从jQuery和JSON.stringify创建的cookie中读取值
- 无法在javascript中首次读取cookie
- 可以't使用ssl读取php中的cookie
- 无法读取 php 中 JavaScript 设置的 cookie
- 使用 c# 编写 cookie,使用 javascript 读取
- 使用 JavaScript 设置、读取和写入 Cookie
- 可以'使用IE11时,不要读取Javascript中的cookie
- Angular无法读取http post响应中的cookie
- 如何使用jquery读取cookie值
- jQuery可以't使用jquery.cookie插件读取cookie
- JavaScript Cookie作用域更改留下2个名称相同但将读取的Cookie
- 读取纯javascript中的cookie(这是一个对象)
- 使用cookie读取html对象的id
- 从Javascript中读取Django会话密钥cookie
- 正在从其他域读取cookie
- 照片库css所选状态未被cookie读取
- 网格从 Cookie 读取位置
- 从 js cookie 读取 .net 代码中的多值 cookie
- Javascript Cookie代码未存储Cookie/读取空Cookie值