内容简介:背景:vue 项目打开 A 页面时 需要将 A 页面的表格数据 存到缓存中 为了使 B 页面 获取到 A 页面的表格数据一开始存放到 sessionstorage 里,但是由于空间有限 缓存存满了所以改用 indexedDB
背景:vue 项目打开 A 页面时 需要将 A 页面的表格数据 存到缓存中 为了使 B 页面 获取到 A 页面的表格数据
一开始存放到 sessionstorage 里,但是由于空间有限 缓存存满了
所以改用 indexedDB
关于 indexedDB 具体的介绍就不说了 可以自行百度
接下来介绍一下我所用到的几个基本方法~
实现如下:
1.首先要 open indexedDB ,然后记住 每个操作都是异步的 需要写在 onsuccess 方法里:
saveindexedDB (data, _case, _control) {
let customerData = data
let dbName = "deg"
var request = indexedDB.open(dbName)
request.onerror = (e) => {}
request.onupgradeneeded = (e) => {
this.db = e.target.result
var objectStore = this.db.createObjectStore("customers", {keyPath:'name', autoIncrement:true}) // 这里将 json 的 name 作为查询数据的 key
}
request.onsuccess = (e) => {
console.log("success!");
this.db = e.target.result
this.updateDBvalue(data,_case, _control)
}
request.onerror = (e) => {
console.log("error!");
}
},
复制代码
2.在这里我需要把表格数据存放到 customers 表里
因为每次打开 A 页面都会重新获取一下这个列表
所以
先判断一下数据库是否有这个表,有则修改,无则添加
updateDBvalue (data, _case, _control) {
var tx = this.db.transaction('customers', 'readwrite');
var store = tx.objectStore('customers');
var req = store.get('deg' + _case + _control);
req.onsuccess = (e) => {
var degData = e.target.result;
if (!degData) {
store.add(data);
} else {
degData.value = data.value;
store.put(degData);
}
}
},
复制代码
3.那么 在 B 页面怎么 获取 到数据库里的列表 并进行下一步操作呢?
getdegList () {
let _case = sessionStorage.getItem('_case')
let _control = sessionStorage.getItem('_control')
let dbName = "deg"
var request = indexedDB.open(dbName)
request.onerror = (e) => {}
request.onupgradeneeded = (e) => {
this.db = e.target.result
var objectStore = this.db.createObjectStore("customers", {keyPath:'name', autoIncrement:true})
}
request.onsuccess = (e) => {
console.log("success!");
this.db = e.target.result
this.setDeg(_case, _control)
}
request.onerror = (e) => {
console.log("error!");
}
},
setDeg (_case, _control) {
var tx = this.db.transaction('customers', 'readwrite')
var store = tx.objectStore('customers')
var req = store.get('deg' + _case + _control) // 获取的就是 列表json 的 name key
req.onsuccess = (e) => {
this.deg = e.target.result.value
}
},
复制代码
ok~那么我们可以看到浏览器端 indexedDB 数据存放的情况啦!
ps:
如果想要 clear 表,方法如下:
clear () {
var tx = this.db.transaction("customers","readwrite")
var store = tx.objectStore("customers")
store.clear()
},
复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 降低云游戏延迟优化云游戏体验:贝塞斯达推出Orion技术,还公布了免费体验计划
- PyTorch 初体验
- golang爬虫初体验
- Netty 入门初体验
- Ansible初体验
- WebAssembly初体验
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
微信小程序入门指南
知晓程序 / 电子工业出版社 / 2017-6-1 / 49
《知晓程序:微信小程序入门指南》是一本分析小程序生态、解读小程序产品设计与开发的入门图书。全书共 9 章,全面讲解了小程序的基本知识、大家如何看待小程序、小程序对行业的影响、小程序对开发者的影响、小程序对用户的影响、开发小程序需要的准备工作等内容,并深入解读了小程序的官方文档。 读者在阅读《知晓程序:微信小程序入门指南》之后可以清楚小程序与订阅号、服务号的区别,了解小程序适用的场景,认识小程......一起来看看 《微信小程序入门指南》 这本书的介绍吧!