什么是cookie ?
cookie:是记录在用户浏览器中的信息,通常情况下是以“键/值”的形式进行存储的,可设置过期的时间.
特征:
1.同一个网站共享一-套cookie.
2.大小有限,-一般都是4kb, 只能存文本
3.必须要通过本地服务器来预览。 不能以file的形式
4.分为临时cookie和设置过期时间的cookie
如以下格式:
name=zhangsan;
name:为键名,也就是cookie记录的变量名
mochu:为cookie记录的值
当web页面向服务器发出请求时,属于此页面的所有cookie信息,也一并上传到服务器,服务器端可以通过对cookie的识别,来辨别出页面的来源或是用户的身份。
js创建 cookie 的方法
方法1:
js中可以通过 document.cookie 来创建 cookie
document.cookie = "Name=zhangsan";
方法2:
创建一个带有过期时间的 cookie ,这里用的是 GMT 时间
document.cookie = "Name=zhangsan ; expires = Sat, 10 Aug 2019 08:55:38 GMT";
注意:如果不设置过期时间,则在浏览器关闭时,cookie自动过期或删除
方法3:
设置cookie的有效果路径,默认情况下,cookie只对当前页面有效果
path=/:表示cookie对web页面所属网站的全部页面有效果,你也可以自定义其它路径
document.cookie = "Name=zhangsan ; expires = Sat, 10 Aug 2019 08:55:38 GMT ;path=/";
自定义js获取 cookie 的函数
document.cookie 获取到的 cookie 都是字符串的形式,我们可以对其获取的结果进行加工,来输出指定的 cookie.
function getCookie(name) {
var arr, reg = new RegExp("(^| )" + name + "=([^;]*)(;|$)");
if (arr = document.cookie.match(reg)){
return unescape(arr[2]);
}else{
return null;
}
}
console.log(getCookie('Name'));
//输出zhangsan
js删除 cookie 的方法
js 删除cookie 的操作非常简单,只要将 cookie 的过期时候设置成比当前时间小就可以了.
function delCookie('Name'); {
var exp = new Date();
exp.setTime(exp.getTime() - 1);
// 这里需要判断一下cookie是否存在
var c = getCookie(name);
if (c != null){
document.cookie = name + "=" + c + ";expires=" + exp.toGMTString();
}
}
delCookie('Name');