背景:vue 项目打开 A 页面时 须要将 A 页面的表格数据 存到缓存中 为了使 B 页面 获取到 A 页面的表格数据html
一开始存放到 sessionstorage 里,可是因为空间有限 缓存存满了vue
因此改用 indexedDB数据库
关于 indexedDB 具体的介绍就不说了 能够自行百度json
接下来介绍一下我所用到的几个基本方法~浏览器
实现以下:缓存
1.首先要 open indexedDB ,而后记住 每一个操做都是异步的 须要写在 onsuccess 方法里:bash
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 表里session
由于每次打开 A 页面都会从新获取一下这个列表异步
因此ui
先判断一下数据库是否有这个表,有则修改,无则添加
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:
1.若是想要 clear customers 表,方法以下:
clear () {
var tx = this.db.transaction("customers","readwrite")
var store = tx.objectStore("customers")
store.clear()
},
复制代码
2.若是想要删除 customers 表里的其中一条数据,咱们能够根据 key 来进行删除
var tx = this.db.transaction('customers', 'readwrite')
var req = tx.objectStore('customers').delete('degAB')
复制代码
---------------------------------------
在这里重点说一下事务 transaction
在向 customers 表里添加数据时,我采用的是 先判断 db 里有没有这条数据 例如 degAB,无则添加,有则不添加。
在第一次从后台获取数据后在 then 方法里添加,报错
Failed to execute 'add' on 'IDBObjectStore': The transaction has finished.复制代码
说明这时事务已经失效了,须要从新创建一个事务,才能进行添加!
若是没有 then 方法,能够直接用 store 添加
---------------------------------------