**
如果您想把 IndexedDB 中的所有数据都拿出来,然后转换为数组格式,可以按照以下步骤操作:
**
- 打开 IndexedDB 数据库和存储对象:
let dbOpenRequest = indexedDB.open(databaseName, databaseVersion);
dbOpenRequest.onsuccess = function(event) {
let db = event.target.result;
let transaction = db.transaction(storeName, "readonly");
let objectStore = transaction.objectStore(storeName);
// 打开游标
let cursorRequest = objectStore.openCursor();
let data = [];
cursorRequest.onsuccess = function(event) {
let cursor = event.target.result;
if (cursor) {
// 将每一个数据对象推入数组中
data.push(cursor.value);
cursor.continue();
} else {
// 所有数据已经处理完毕,将数据数组返回
console.log(data);
}
};
};
- 打开游标,使用 openCursor 函数遍历存储对象中的数据。
将每一个数据对象推入数组中。
当所有数据处理完毕后,将数据数组返回。
完整的代码示例如下所示:
let databaseName = "myDatabase";
let databaseVersion = 1;
let storeName = "myStore";
let dbOpenRequest = indexedDB.open(databaseName, databaseVersion);
dbOpenRequest.onsuccess = function(event) {
let db = event.target.result;
let transaction = db.transaction(storeName, "readonly");
let objectStore = transaction.objectStore(storeName);
let cursorRequest = objectStore.openCursor();
let data = [];
cursorRequest.onsuccess = function(event) {
let cursor = event.target.result;
if (cursor) {
data.push(cursor.value);
cursor.continue();
} else {
console.log(data);
}
};
};