JavaScript Cookie的读取和写入函数

yizhihongxing

下面我们来详细讲解如何读取和写入JavaScript Cookie。

什么是Cookie?

Cookie是在Web浏览器中存储的小数据文件。通常,当您第一次访问一个网站时,该网站将会创建一个Cookie,并存储在您的计算机上。当您访问该网站的其他页面时,该Cookie会被发送回该网站,以便它可以“记住”您的首选项或其他设置。

如何读取和写入Cookie?

写入Cookie

我们可以使用以下JavaScript代码来写入Cookie:

function setCookie(name, value, days) {
  var expires = "";
  if (days) {
    var date = new Date();
    date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
    expires = "; expires=" + date.toUTCString();
  }
  document.cookie = name + "=" + (value || "") + expires + "; path=/";
}

参数说明:
- name:要设置的Cookie的名称
- value:Cookie的值
- days:Cookie的生命周期,以天数为单位

例如,我们可以使用以下代码将名称为“username”的Cookie设置为“John”,生命周期为1天。

setCookie("username", "John", 1);

读取Cookie

我们可以使用以下JavaScript代码来读取Cookie:

function getCookie(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;
}

参数说明:
- name:要读取的Cookie的名称

例如,我们可以使用以下代码来获取名称为“username”的Cookie的值:

var username = getCookie("username");

如果Cookie存在,则键“username”将包含“John”;否则,键“username”将为空。

示例说明

示例1:写入和读取Cookie

以下代码将存储名称为“username”的Cookie,值为“John”,生命周期为1天。并使用getCookie函数读取该Cookie,并在控制台输出其值。

function setCookie(name, value, days) {
  var expires = "";
  if (days) {
    var date = new Date();
    date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
    expires = "; expires=" + date.toUTCString();
  }
  document.cookie = name + "=" + (value || "") + expires + "; path=/";
}

function getCookie(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;
}

setCookie("username", "John", 1);
var username = getCookie("username");
console.log(username); // 输出John

示例2:在不同子页面之间共享Cookie

以下代码演示了如何在不同的子页面之间共享Cookie。当我们在页面1上存储了Cookie时,我们可以在页面2上访问相同的Cookie。

页面1

function setCookie(name, value, days) {
  var expires = "";
  if (days) {
    var date = new Date();
    date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
    expires = "; expires=" + date.toUTCString();
  }
  document.cookie = name + "=" + (value || "") + expires + "; path=/";
}

setCookie("username", "John", 1);

页面2

function getCookie(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;
}

var username = getCookie("username");
console.log(username); // 输出John

注意:需要在两个页面上包含setCookie和getCookie函数定义。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript Cookie的读取和写入函数 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • JavaScript中DOM和BOM原理详析

    JavaScript中DOM和BOM原理详析 什么是DOM? DOM(文档对象模型)是JavaScript操作网页的接口,它将网页文档看成一个树形结构,可以通过JavaScript来操作这个树形结构中的各个节点。HTML中的标签、文本和属性都被表示为树中的节点,节点与节点之间有父子和兄弟关系。 DOM接口 DOM提供了一系列的API,可以通过这些API对节点…

    JavaScript 2023年6月10日
    00
  • url参数中有+、空格、=、%、&、#等特殊符号的问题解决

    针对url参数中包含特殊符号导致的问题,可以采取以下措施进行解决: 一、使用URL编码 URL编码是将URL中的非英文字母和数字都用百分号(%)加两个16进制数字表示的方式进行转换,以确保它们能够正常传输和处理。常用的URL编码方法是使用Javascript内置对象encodeURIComponent()函数。例如: https://www.example.…

    JavaScript 2023年5月19日
    00
  • js日期插件dateHelp获取本月、三个月、今年的日期

    要获取本月、三个月、今年的日期,可以使用JS日期插件dateHelp。下面是使用dateHelp的完整攻略: 步骤一:引入dateHelp插件 在HTML文件中,引入dateHelp.js。 <script src="path/to/dateHelp.js"></script> 步骤二:获取本月日期 要获取本月日期…

    JavaScript 2023年6月10日
    00
  • 一文带你搞懂JavaScript中的进制与进制转换

    一文带你搞懂JavaScript中的进制与进制转换 1. 进制概念 进制是数学中的一个概念,一般用来表示数的基数,也就是每一位可使用的数字个数。常见的进制有十进制、二进制和十六进制。 十进制:使用 0~9 这10个数字表示,每一位值的大小是10的n次方,其中n是这一位数字的位置。 二进制:使用 0 和 1 两个数字表示,每一位值的大小是2的n次方,其中n是这…

    JavaScript 2023年5月19日
    00
  • JavaScript、C# URL编码、解码总结

    JavaScript、C# URL编码、解码总结 在进行URL传输时,为了防止特殊字符导致的错误,需要对URL进行编码。JavaScript和C#都提供了URL编码、解码的方法。 JavaScript URL编码、解码 在JavaScript中,可以使用encodeURI、encodeURIComponent对URL进行编码,使用decodeURI、deco…

    JavaScript 2023年5月20日
    00
  • element中的$confirm的使用

    当在Vue项目中使用Element UI组件库时,我们可以利用Element中提供的许多组件和方法,如对话框、表格、表单等。其中,$confirm方法是Element UI提供的一个强大的提示框组件,可以方便地实现弹出二次确认框,并在点击确认/取消按钮后返回用户选择的结果。下面是关于如何使用Element中的$confirm方法的详细攻略: 1. 引入Ele…

    JavaScript 2023年6月10日
    00
  • js获取指定的cookie的具体实现

    获取指定的Cookie需要以下步骤: 获取所有Cookie:使用document.cookie属性获取当前页面所有的Cookie,它返回值是一个字符串,其中每个Cookie之间使用分号和空格分隔。 将Cookie字符串转化为对象:使用JavaScript的split()方法将Cookie字符串分割成一个个单独的键值对,再使用for循环遍历所有的键值对,并使用…

    JavaScript 2023年6月11日
    00
  • JavaScript 声明私有变量的两种方式

    下面是JavaScript声明私有变量的两种方式的完整攻略。 声明私有变量的两种方式 在JavaScript中,私有变量是指只能在类或对象内部访问的变量。通常情况下,我们用闭包或Symbol来实现私有变量的声明。 1. 闭包实现私有变量 闭包是指一个函数返回另一个函数,这个被返回的函数可以访问原函数的内部变量。下面来看一个闭包实现私有变量的示例: funct…

    JavaScript 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部