[英]how to store a mongodb array of collections inside an indexedDB
您好,我想为我的phonegap建立一个本地数据库,以便用户可以离线使用它。
我在创建数据库的角度函数中具有此功能。
function Database() {
return {
create: function (itemDocs) {
var db = null;
var request = indexedDB.open("myDB", 1);
request.onsuccess = function (event) {
db = event.target.result;
console.log("DB loaded successfully");
};
request.onerror = function (event) {
console.log(event)
};
request.onupgradeneeded = function (event) {
db = event.target.result;
console.log("DB initiliazed / created");
//create collections
db.createObjectStore("items", {keyPath: "_id"});
//create documents
var transaction = db.transaction(["items"], "readwrite");
var items = transaction.objectStore("items");
items.add(itemDocs);
};
}
}
}
itemDocs拥有一个mongoDB集合(这是一个对象数组),我想将该集合存储在indexedDB数据库中,问题是我遇到了这个烦人的错误。
Uncaught InvalidStateError: Failed to execute 'transaction' on 'IDBDatabase': A version change transaction is running.
使用var transaction = event.target.transaction
而不是var transaction = db.transaction(...);
完整的答案相当冗长。 简而言之,您不需要在onupgradeneed上创建新事务。 您已经有一个有效的交易。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.