博客
关于我
js设置Cookie
阅读量:169 次
发布时间:2019-02-28

本文共 1700 字,大约阅读时间需要 5 分钟。

cookie与session是Web开发中常用的信息存储方式。Cookie是在客户端开辟的一块可存储用户信息的地方,而Session是在服务器内存中开辟的一块存储用户信息的地方。两者在数据存储的位置和使用场景上有显著区别。

JavaScript是运行在客户端的脚本,因此一般不能直接设置Session,因为Session是运行在服务器端的。而Cookie是运行在客户端的,因此可以通过JavaScript来设置Cookie。然而,使用JavaScript的全局变量或静态变量在页面跳转或关闭时,其值会随着页面重新加载而丢失,这种方式难以实现真正的数据持久化保存。

要解决这一问题,JavaScript可以通过设置Cookie来保存变量值。以下是设置和读取Cookie的基础知识和实践方法。

Cookie的结构

Cookie的值部分通常以键值对的形式存在,各个Cookie值之间用分号分隔。具体结构如下:

key=value;key2=value2;...

在JavaScript中,通过document.cookie属性可以访问和修改Cookie的值。

设置Cookie

在A页面中通过JavaScript设置变量值到Cookie中,B页面可以通过读取该Cookie获取变量值。以下是设置Cookie的常用方式:

document.cookie = "name=" + encodeURIComponent(username) + ";Path=/";

此外,为了控制Cookie的过期时间,可以通过指定expires参数来设置有效期。例如,以下代码设置一个30天内有效的Cookie:

var expires = new Date();expires.setTime(expires.getTime() + 30 * 24 * 60 * 60 * 1000);document.cookie = "username=" + encodeURIComponent("jack") + ";Path=/;expires=" + expires.toGMTString();

读取Cookie

在B页面中,通过JavaScript读取A页面设置的Cookie值,可以直接访问document.cookie属性并解析其中的值。例如:

var username = document.cookie.split(";").find(function(item) {    return item.split("=")[1] === "jack";}).split("=")[1];

删除Cookie

有时需要删除某个Cookie,可以通过设置其过期时间为过去的时间来实现:

var today = new Date();today.setTime(today.getTime() - 1);document.cookie = "username=" + encodeURIComponent("jack") + ";Path=/;expires=" + today.toGMTString();

自定义过期时间

如果需要对Cookie的有效期进行自定义设置,可以通过以下方法实现:

function setCookie(name, value, days) {    var expires = new Date();    expires.setTime(expires.getTime() + days * 24 * 60 * 60 * 1000);    document.cookie = name + "=" + encodeURIComponent(value) + ";Path=/;expires=" + expires.toGMTString();}

示例代码

以下是一个完整的示例,展示了如何在两个页面之间传递变量值:

通过以上方法,可以在跨页面的JavaScript应用中有效地传递变量值,而无需依赖Session或其他服务器端技术。

转载地址:http://wtyj.baihongyu.com/

你可能感兴趣的文章
Osgi环境配置
查看>>
OSG——选取和拖拽
查看>>
OSG中找到特定节点的方法(转)
查看>>
OSG学习:C#调用非托管C++方法——C++/CLI
查看>>
OSG学习:OSG组成(三)——组成模块(续):OSG核心库中的一些类和方法
查看>>
OSG学习:OSG组成(二)——渲染状态和纹理映射
查看>>
OSG学习:WIN10系统下OSG+VS2017编译及运行
查看>>
OSG学习:人机交互——普通键盘事件:着火的飞机
查看>>
OSG学习:几何体的操作(一)——交互事件、简化几何体
查看>>
OSG学习:几何体的操作(二)——交互事件、Delaunay三角网绘制
查看>>
OSG学习:几何对象的绘制(一)——四边形
查看>>
OSG学习:几何对象的绘制(三)——几何元素的存储和几何体的绘制方法
查看>>
OSG学习:几何对象的绘制(二)——简易房屋
查看>>
OSG学习:几何对象的绘制(四)——几何体的更新回调:旋转的线
查看>>
OSG学习:场景图形管理(一)——视图与相机
查看>>
OSG学习:场景图形管理(三)——多视图相机渲染
查看>>
OSG学习:场景图形管理(二)——单窗口多相机渲染
查看>>
OSG学习:场景图形管理(四)——多视图多窗口渲染
查看>>
OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
查看>>
Sql 随机更新一条数据返回更新数据的ID编号
查看>>