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);}}

 

 

 

相关内容

热门资讯

武汉摩尔影城安卓系统APP,便... 你有没有想过,一部手机就能带你走进电影的世界,享受大屏幕带来的震撼?今天,就让我带你详细了解武汉摩尔...
联想刷安卓p系统,畅享智能新体... 你有没有发现,最近联想的安卓P系统刷机热潮可是席卷了整个互联网圈呢!这不,我就迫不及待地来和你聊聊这...
mac从安卓系统改成双系统,双... 你有没有想过,你的Mac电脑从安卓系统改成双系统后,生活会有哪些翻天覆地的变化呢?想象一边是流畅的苹...
kindke安卓系统激活码,激... 亲爱的读者,你是否在寻找一款能够让你手机焕然一新的操作系统?如果你是安卓用户,那么今天我要给你带来一...
萤石云监控安卓系统,安卓系统下... 你有没有想过,家里的安全可以随时随地掌握在手中?现在,有了萤石云监控安卓系统,这不再是梦想啦!想象无...
手机安卓系统会不会爆炸,系统升... 手机安卓系统会不会爆炸——一场关于安全的探讨在当今这个数字化的世界里,手机已经成为我们生活中不可或缺...
安卓系统双清详图解,恢复出厂设... 你有没有遇到过手机卡顿、运行缓慢的问题?别急,今天就来给你详细解析一下安卓系统的“双清”操作,让你的...
召唤抽奖系统安卓直装,轻松体验... 你知道吗?现在市面上有一种特别火的玩意儿,那就是召唤抽奖系统安卓直装。是不是听起来就让人心动不已?没...
系统工具箱安卓2.3,深度解析... 你有没有发现,手机里的那些小工具,有时候就像是个神奇的百宝箱呢?今天,就让我带你一探究竟,看看安卓2...
华硕平板安卓刷机系统,解锁性能... 亲爱的数码爱好者们,你是否曾为你的华硕平板安卓系统感到厌倦,想要给它来一次焕然一新的体验呢?那就跟着...
鸿蒙系统与安卓怎么区别,差异解... 你有没有发现,最近手机圈子里有个大热门,那就是鸿蒙系统和安卓系统的区别。这两位“系统大侠”各有各的绝...
红帽系统怎么刷回安卓,红帽系统... 你是不是也和我一样,对红帽系统刷回安卓充满了好奇?别急,今天就来给你详细揭秘这个过程,让你轻松上手,...
ios安卓联想三系统,全面解析... 你有没有发现,现在的手机市场真是热闹非凡呢!各种操作系统轮番登场,让人眼花缭乱。今天,就让我带你来聊...
安卓调用系统相机并存盘,And... 你有没有想过,手机里的照片和视频,是怎么被我们随手拍下,又神奇地存到手机里的呢?今天,就让我带你一探...
安卓4.0原生系统下,引领智能... 你有没有发现,安卓4.0原生系统下,手机的使用体验简直就像打开了新世界的大门?今天,就让我带你一起探...
安卓c13系统,创新功能与性能... 你知道吗?最近安卓系统又来了一次大更新,那就是安卓C13系统。这可不是一个小打小闹的更新,而是带来了...
鸿蒙3.0脱离安卓系统,开启全... 你知道吗?最近科技圈可是炸开了锅,因为华为的新操作系统鸿蒙3.0横空出世,竟然宣布要脱离安卓系统,这...
安卓怎么应对苹果系统,安卓系统... 你知道吗?在智能手机的世界里,安卓和苹果就像是一对相爱相杀的恋人。安卓系统,这位多才多艺的“大众情人...
安卓系统如何开橱窗教程,安卓系... 你有没有想过,你的安卓手机里也能开个橱窗,展示那些你心爱的宝贝?没错,就是那种可以随时翻看、随时分享...
安卓系统软件APK,深入探究安... 你有没有发现,手机里的那些好玩的应用,其实都是靠一个小小的文件来“住”进去的?没错,就是安卓系统里的...