hi,欢迎访问本站!
当前位置: 首页Web前端正文

JS如何设置cookie、读取cookie、删除cookie

墨初 Web前端 964阅读

cookie在前端的作用是很大的,可以临时存储一些信息,比如用户的账号,用户的TOKEN以及其它的一些信息等。下面的博文73so博客就给大家说说在前端中如何使用JS脚本来设置cookie,读取cookie以及删除cookie。

什么是cookie ?

cookie:用于在浏览器中记录指定的信息,也可以设置存储的有效时间。

注:cookie是以键名和键值对比存在的,键名为cookie记录的变量名,键值为cookie的记录值。

当web页面向服务器发出请求时,属于此页面的所有cookie信息,也一并上传到服务器,服务器端可以通过对cookie的识别,来辨别出页面的来源或是用户的身份。

js创建 cookie 的方法

在js脚本中可以通过下面的几个方法来创建cookie.

方法1:

可以直接创建一个 cookie

document.cookie = "Name=mochu";

方法2:

创建一个带有过期时间的 cookie ,这里用的是 GMT 时间

document.cookie = "Name=mochu ; expires = Sat, 10 Aug 2019 08:55:38 GMT";

注意:如果不设置过期时间,则在浏览器关闭时,cookie自动过期或删除

方法3:

设置cookie的有效果路径,默认情况下,cookie只对当前页面有效果

path=/:表示cookie对web页面所属网站的全部页面有效果,你也可以自定义其它路径

document.cookie = "Name=mochu ; expires = Sat, 10 Aug 2019 08:55:38 GMT ;path=/";

JS设置 cookie 的函数

函数代码

/**
 * name 设置cookie
 * @param string name cookie名
 * @param string value cookie值
 * @param int time cookie过期时间以秒为单位
 * @param string path cookie的路径
 * 
 * @return 
 * @host https://www.73so.com
 */
function setCookie(name, value, time='',path='') 
{
    if(time && path){
        var strsec = time * 1000;
        var exp = new Date();
        exp.setTime(exp.getTime() + strsec * 1);
        document.cookie = name + "=" + escape(value) + ";expires=" + exp.toGMTString() + ";path="+path;
    }else if(time){
        var strsec = time * 1000;
        var exp = new Date();
        exp.setTime(exp.getTime() + strsec * 1);
        document.cookie = name + "=" + escape(value) + ";expires=" + exp.toGMTString();
    }else if(path){
        document.cookie = name + "=" + escape(value) + ";path="+path;
    }else{
        document.cookie = name + "=" + escape(value);
    }
}
// setCookie("Name", "mochu", 20);

js读取 cookie 的方法

js 可以使用下面的代码来读取cookie.

例:

var x = document.cookie;

document.cookie,会以字符串的形式反回所有的cookie

例:

setCookie("Name", "mochu",20,'/');
setCookie("pass", "123", 20, '/');
var x = document.cookie;
console.log(x);
// Name=mochu; pass=123

js获取 cookie 的函数

下面是自定义的一个用于读取cookie的函数,可以通过指定的cookie键名读取其相应的cookie值。

/**
 * name 读取指的cookie
 * @param string name cookie名
 * 
 * @return cookie键值,如没有则返回null
 * @host https://www.73so.com
 */
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'));

js删除 cookie 的方法

js 删除cookie 的操作非常简单,只要将 cookie 的过期时候设置成比当前时间小就可以了

自定义函数代码:

/**
 * @name 删除指的cookie
 * @param string name cookie名
 * 
 * @return 
 * @host https://www.73so.com
 */
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');
声明:无特别说明,转载请标明本文来源!
相关推荐