js学习11(客户端存储)
创始人
2025-05-30 13:44:21
0

目录

web storage

IndexDB


 

web storage

### 前言:
(1) web storage方式用于存储简单的数据(字符串或数字)到客户端浏览器,实现对象为sessionStorage和localStorage;
(2) 其中sessionStorage随着浏览器的关闭而销毁,而localStorage在浏览器关闭时不会销毁(所以后者更为常用);
(3) 通过web storage方式存储的数据在不同页面加载时也会存在;

 

 

### web storage操作
## 添加或修改数据
localStorage.setItem('key1','value1');
sessionStorage.setItem('key1','value1');
## 获取数据
localStorage.getItem('key1');
sessionStorage.getItem('key1');
## 删除数据
localStorage.removeItem('key1');
sessionStorage.removeItem('key1');

 

 

### 总结:
(1) web storage方式存储,就存储时效而言,localStorage更为常用
(2) web storage方式在不同页面都会携带存在,所以存在安全问题

IndexDB

为每个域名分离存储,存储容量大,且可以存储复杂的数据类型,实现持久化存储。是非关系数据库,以键值对形式存储数据。支持事务,是异步操作。

let db;
// 1. 请求打开数据库
const request = window.indexedDB.open('testDB', 1);// 2. 初始化数据库:创建仓库、定义索引
request.onupgradeneeded = function(evt) {/*  监听器:onupgradeneeded初始化数据库或者高版本数据库请求时调用;该方法在onsuccess或onerror之前调用;*/db = evt.target.result;console.log(111,db);// 创建仓库const objectStore = db.createObjectStore('test1', { keyPath: 'id', autoIncrement:true });// 定义索引objectStore.createIndex('t1', 't1', { unique: false });objectStore.createIndex('t2', 't2', { unique: false });console.log('数据库初始化完成,仓库和索引创建成功');
};// 3. 数据库请求监听
// 3.1 请求失败
request.onerror = () =>{console.error('失败,打开数据库')
};
// 3.2 请求成功
request.onsuccess =  () => {db = request.result;console.log('成功,打开数据库');
};// 4. 添加数据
function addData() {const transaction = db.transaction(['test1'], 'readwrite');const objectStore = transaction.objectStore('test1');objectStore.add({ t1: 'joden', t2: 'lisi' });transaction.oncomplete =  () => {console.log('成功,添加数据');};transaction.onsuccess = ()=>{console.log('失败,添加数据');}}
// 5. 查看数据
function displayData() {var data = [];const transaction = db.transaction(['test1'], 'readwrite');const objectStore = transaction.objectStore('test1');objectStore.openCursor().onsuccess =  function(evt){const cursor = evt.target.result;if (cursor) {data.push(cursor.value)cursor.continue();}}// 查看数据objectStore.openCursor().onsuccess = ()=>{console.log(data);}
}
// 6. 删除数据
function deleteData(id){const transaction = db.transaction(['test1'], 'readwrite');const objectStore = transaction.objectStore('test1');let res = objectStore.delete(id);res.onsuccess = ()=>{console.log('成功删除数据',id);}}

 

 

 

相关内容

热门资讯

块级元素和行内元素 一、块级元素和行内元素 行内元素:         常见的行内元素: a、span、b、img、st...
shell 部分内置变量 说明 这些变量都是由bash这个程序本身进行修改使用; 其他shell不一定试用; 变量 $_ to...
链表(没做完。。) BM1 反转链表 给定一个单链表的头结点pHead(该头节点是有值的,比如在下图&#...
十九、互斥量(互斥锁) 文章目录1、基本概念2、使用场景:用于实现对临界资源的独占式处理(能够解...
springboot控制层消息... 大概了解三种方式: 1.区别在于WebMvcConfigurerAdapter 新版本...
2023年湖北安全员ABC证书...   2023年湖北安全员ABC证书报名入口!报考条件?启程别 证...
蓝桥杯倒计时 | 倒计时18天 作者🕵️‍♂️:让机器理解语言か 专栏🎇:...
pandas读CSV、读JSO... 学习让我快乐   pandas的数据读取基本操作 pandas是Python中非常流行的数据处理库...
Hybrid App开发模式 Hybrid App(混合模式移动应用)是指介于web-app、nati...
SQL预编译和批量提交对性能提... 背景 一个项目,从kafka获取数据后,经过业务处理,生成...
C++ Lambda表达式的常... ⭐️我叫忆_恒心,一名喜欢书写博客的在读研究生👨‍🎓。...
【总结】docker 安装教程 各操作系统版本下载地址 mac 版:https://download.docker.c...
12 致远OA开发规范 开发案例(业务扩展接口) 1.客开开发前缀约束: 为了快速区分标准开发与客开开发&#x...
文件包含漏洞全面详解 文件包含漏洞总结一、什么是文件包含漏洞二、本地文件包含漏洞(LFI)三、LFI漏洞利用技巧1.配合文...
【C++进阶】unordere... 文章目录unordered系列容器介绍unordered_setunordered_set的模板参数...
【Linux】学会这些基本指令... 前言上篇文章介绍了一些常用的指令,这篇文章再来介绍一下Linux必须学会的指令。一.时...
panbas学习篇(一)数据的... 最大值最小值 Series.sum : Return the sum.Series.min : Re...
西安石油大学期末C语言重点题目... C语言重点知识点总结 ##例题4-7 (switch和字符的读入) ...
QML- QML视觉元素类型 QML视觉元素类型一、概述一、图像类型三、共享视觉属性1. 不透明度和可见性2. 转换(...
【 Linux入门 】之 手搓... 目的基本结构提取输入命令fgets的使用命令初步处理命令的本质创建子进程重要知识补充进程替换命令处理...