JavaScript 获取浏览器本地数据的4种方式

news2024/11/24 8:05:33

JavaScript 获取浏览器本地数据的方式

我们在做Web开发中,客户端存储机制对于在浏览器中持久化数据至关重要。这些机制允许开发者存储用户偏好设置、应用状态以及其他关键信息,从而增强用户体验。本文将介绍几种常用的JavaScript获取浏览器本地数据的方式,包括localStoragesessionStorageCookiesIndexedDB,并提供相应的代码示例。
在这里插入图片描述

1. localStorage

localStorage 提供了一种方式来存储数据在用户的本地计算机上,并且没有过期时间。这意味着存储的数据将在浏览器关闭后仍然存在,直到被显式删除。

代码示例

// 存储数据
localStorage.setItem('username', 'JohnDoe');

// 获取数据
let username = localStorage.getItem('username');
console.log(username); // 输出: JohnDoe

// 删除数据
localStorage.removeItem('username');

// 清除所有数据
// localStorage.clear();

2. sessionStorage

sessionStoragelocalStorage 类似,但它存储的数据仅在当前会话期间有效。一旦页面会话结束(例如,当用户关闭浏览器标签页或窗口时),存储的数据将被删除。

代码示例

// 存储数据
sessionStorage.setItem('sessionId', '12345');

// 获取数据
let sessionId = sessionStorage.getItem('sessionId');
console.log(sessionId); // 输出: 12345

// 注意:关闭页面会话后,该数据将不再可用
// 删除数据
// sessionStorage.removeItem('sessionId');

// 由于 sessionStorage 会随着页面会话的结束而自动清除,通常不需要手动清除所有数据
// 但如果你确实需要,可以使用 sessionStorage.clear();

3. Cookies

Cookies 是服务器发送到用户浏览器并存储在本地的一小块数据。它们通常用于跟踪用户会话、存储用户偏好设置等。尽管 Cookies 可以在客户端通过 JavaScript 访问,但它们的设置和读取通常更多地与服务器端交互相关。

代码示例

// 设置 Cookie
document.cookie = "theme=light; expires=Thu, 01 Jan 2030 00:00:00 GMT; path=/";

// 获取所有 Cookies 并解析出特定的 Cookie
function getCookie(name) {
    let matches = document.cookie.match(new RegExp(
        "(?:^|; )" + name.replace(/([\.$?*|{}\(\)\[\]\\\/\+^])/g, '\\$1') + "=([^;]*)"
    ));
    return matches ? decodeURIComponent(matches[1]) : undefined;
}

let theme = getCookie('theme');
console.log(theme); // 输出: light

// 删除 Cookie
document.cookie = "theme=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/";

4. IndexedDB

IndexedDB 是一个低级的API,用于客户端存储大量结构化数据,包括文件/二进制对象。它提供了异步的、基于事务的API。

代码示例

// 打开(或创建)数据库
let request = indexedDB.open("myDatabase", 1);

request.onupgradeneeded = function(event) {
    let db = event.target.result;
    // 创建一个新的对象存储(表)
    let objectStore = db.createObjectStore("customers", { keyPath: "id" });
};

request.onsuccess = function(event) {
    let db = event.target.result;

    // 添加数据
    let transaction = db.transaction(["customers"], "readwrite");
    let objectStore = transaction.objectStore("customers");
    let request = objectStore.add({id: 1, name: "John Doe", age: 30, email: "john.doe@example.com"});

    request.onerror = function(event) {
        console.error("Error adding data: ", event.target.errorCode);
    };

    request.onsuccess = function(event) {
        console.log("Data added successfully");
    };

    // 获取数据
    let getRequest = objectStore.get(1);
    getRequest.onsuccess = function(event) {
        let customer = event.target.result;
        console.log(customer.name); // 输出: John Doe
    };

    transaction.oncomplete = function(event) {
        db.close();
    };
};

request.onerror = function(event) {
    console.error("Database error: ", event.target.errorCode);
};

总结

选择哪种存储机制取决于你的具体需求。localStoragesessionStorage 是最简单的选择,适用于存储小量数据。Cookies 则更多地用于跨请求保持会话状态。而 IndexedDB 提供了更强大的功能,适用于需要存储大量结构化数据的场景。

课程推荐

诚邀你关注我的精品视频课程《ChatGPT+AI项目实战,打造多端智能虚拟数字人》。
课程以项目实战的方式,基于ChatGPT完成多端全栈式开发,实现AI绘画、智能语音、数字虚拟人等,从0到1手把手带你打造一个专属对话虚拟人。通过语音唤醒、识别及合成、安卓开发、前后端快速搭建等技术,使你具备将AI技术真实落地工作中,高效快速提高自身核心竞争力。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2194335.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【无人机设计与控制】基于蜣螂优化算法的无人机三维路径规划Matlab程序

摘要 使用蜣螂优化算法(Dung Beetle Optimization, DBO),本文提出了一种无人机三维路径规划方法。该算法借鉴蜣螂导航行为,结合无人机避障需求,在复杂三维环境中生成最优路径。实验结果表明,基于DBO的路径…

Redis主从复制(replica)、哨兵

一、Redis主从复制介绍: 主从复制,master主机以写为主,slave从机以读为主,当主机数据变化的时候自动将新的数据异步同步到其他从机数据库;能够实现读写分离, 容灾恢复、 数据备份以及水平扩容支撑高并发 二、实现方法…

在ubuntu好部署jenkins发布vue项目时遇到的一些问题及解决方法以及使用jenkins发布vue项目-npm自动打包发布的实现

一、在ubuntu好部署jenkins发布vue项目时遇到的一些问题及解决方法 1. 问题:webpack-dev-server不是内部或外部命令,也不是可运行的程序 解决:使用webpack要安装webpack-cli这个包,才可以调用webpack和webpack-dev-server这些命…

C++——模拟实现stack和queue

1.传统模拟方式 namespace jxy {template<class T>class stack{//...private:T* _a;size_t _size;size_t _capacity;}; } 2.适配器方式模拟 namespace jxy {template<class T,class Container>class stack{public:void push(const T& x){_con.push_back(x);…

No.6 笔记 | Linux操作系统基础:全面概览与核心要点

1. 简介与历史 1.1 起源 创始人&#xff1a;Linus Torvalds&#xff08;芬兰赫尔辛基大学学生&#xff09;初衷&#xff1a;设计一个替代Minix的全功能Unix操作系统首次发布&#xff1a;1991年10月5日&#xff0c;Linux v0.01版本 2. Linux特点 多用户多任务&#xff1a;用…

【Python】PDFMiner.six:高效处理PDF文档的Python工具

PDF是一种广泛使用的文件格式&#xff0c;特别适用于呈现固定布局的文档。然而&#xff0c;提取PDF文件中的文本和信息并不总是那么简单。幸好有许多Python库可以帮助我们&#xff0c;其中&#xff0c;PDFMiner.six 是一个功能强大、专门用于PDF文档解析的库。 ⭕️宇宙起点 &a…

计算机毕业设计 基于Python的老年人健康预警系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

数据仓库拉链表

数仓拉链表是数据仓库中常用的一种数据结构&#xff0c;用于记录维度表中某个属性的历史变化情况。在实际应用中&#xff0c;数仓拉链表可以帮助企业更好地进行数据分析和决策。 数仓拉链表&#xff08;Slowly Changing Dimension, SCD&#xff09;是一种用于处理维表中数据变化…

Linux驱动开发——新字符设备驱动开发

文章目录 1 概述2 新字符设备驱动原理2.1 分配和释放设备号2.2 新字符设备注册方法 3 自动创建设备节点3.1 mdev机制3.2 创建和删除类3.3 创建设备 4 设置文件私有数据5 实验程序编写 系列文章&#xff1a; Linux驱动开发——字符设备驱动开发 Linux驱动开发——LED驱动开发 1 …

24最新从零开始教你玩转ComfyUI-保姆级部署教程-手把手带你ComfyUI工作流搭建!

前言 第一节&#xff1a;认识ComfyUI并安装 本教程专为初学者设计&#xff0c;详细介绍了 2024 年最新版的SD ComfyUI的使用方法。通过逐步指导&#xff0c;让你无需任何基础&#xff0c;快速学会并使用这一强大的AI绘图工具。 1、什么是comfyui ComfyUI就像拥有一支神奇魔…

如何定位前后端Bug?

问题&#xff1a; 假设你在某购物网站上&#xff0c;购买了两件商品&#xff0c;一件打折的&#xff0c;一件不打折的&#xff0c;当你下完订单并且成功支付之后&#xff0c;再去我的订单中查看订单内容时&#xff0c;发现两件商品只显示出来一件&#xff0c;打折的商品并没有显…

最强AI绘画大模型Flux可以在SDWebUI 上使用了!超便捷的Flux模型使用教程!AI绘画零基础入门到实战教程

大家好&#xff0c;我是画画的小强 目前最强的AI绘画大模型Flux.1 横空出世有段时间了&#xff0c;模型效果也得到了广泛的认可&#xff0c;但是 Stable Diffusion WebUI 官方迟迟没有跟进&#xff0c;据说是因为要修改很多底层的处理机制&#xff0c;加之ComfyUI如火如荼&…

基于Springboot的宠物咖啡馆平台的设计与实现(源码+定制+参考)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

高颜值自适应博客主题Puock WordPress主题

一款基于WordPress开发的高颜值的自适应主题&#xff0c;支持白天与黑夜模式。 安装&#xff1a; 请到 发行版本 中进行下载最新版本&#xff0c;然后到WordPress管理后台中的「外观」-「主题」中点击「添加」&#xff0c;选择Puock的主题包进行上传安装并启用即可。 提示&am…

【JVM】深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制

我的主页&#xff1a;2的n次方_ 1. JVM 内存区域划分 程序计数器&#xff08;空间比较小&#xff09;。保存了下一条要执行的指令的地址&#xff08;指向元数据区指令的地址&#xff09;堆。JVM 最大的空间&#xff0c;new 出来的对象都在堆上栈。函数中的局部变量&#x…

【Linux探索学习】第三弹——Linux的基础指令(下)——开启新篇章的大门

Linux基础指令&#xff08;上&#xff09;&#xff1a; 【Linux探索学习】第一弹——Linux的基本指令&#xff08;上&#xff09;——开启Linux学习第一篇-CSDN博客 Linux基础指令&#xff08;中&#xff09;&#xff1a; 【Linux探索学习】第二弹——Linux的基础指令&#…

vmstat命令:系统性能监控

一、命令简介 ​vmstat​ 是一种在类 Unix 系统上常用的性能监控工具&#xff0c;它可以报告虚拟内存统计信息&#xff0c;包括进程、内存、分页、块 IO、陷阱&#xff08;中断&#xff09;和 CPU 活动等。 ‍ 二、命令参数 2.1 命令格式 vmstat [选项] [ 延迟 [次数] ]2…

18734 拓扑排序

### 思路 1. **建模问题**&#xff1a;将课程和依赖关系建模为有向图&#xff0c;其中课程是节点&#xff0c;依赖关系是有向边。 2. **选择算法**&#xff1a;使用拓扑排序算法来确定课程的学习顺序。由于需要确保输出唯一性&#xff0c;同等条件下编号小的课程排在前面&…

Koa学习

Koa 安装与配置 1. 初始化项目 在终端中执行以下命令&#xff1a; # 创建项目文件夹 mkdir koa cd koa# 初始化并安装依赖 npm init -y npm install koa npm install nodemon --save-dev2. 修改 package.json 在 package.json 文件中进行如下修改&#xff1a; {"type…

LeetCode讲解篇之1143. 最长公共子序列

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 这题我们可以采用动态规划求解&#xff0c;用一个二维数组记录text1的0 ~ i区间子串和text2的0 ~ j区间子串的最长公共子序列的长度&#xff0c;我们假设该二维数组是f 这个数组有一个特性&#xff0c;如果a <…