在镀铬/歌剧,有一个非标准的API webkitGetDatabaseNames()的Dexie.js用于检索当前的源数据库的名称列表。对于其他浏览器,Dexie通过为每个来源保留最新的数据库名称数据库来模拟此API,因此:
对于铬浏览器,Dexie.getDatabaseNames()将列出当前原点的所有数据库,但是对于非铬浏览器,只会显示使用Dexie创建的数据库。
如果您需要转储每个数据库的内容,看看this issue,基本上得出:
interface TableDump {
table: string
rows: any[]
}
function export(db: Dexie): TableDump[] {
return db.transaction('r', db.tables,()=>{
return Promise.all(
db.tables.map(table => table.toArray()
.then(rows => ({table: table.name, rows: rows})));
});
}
function import(data: TableDump[], db: Dexie) {
return db.transaction('rw', db.tables,() => {
return Promise.all(data.map (t =>
db.table(t.table).clear()
.then(()=>db.table(t.table).bulkAdd(t.rows)));
});
}
结合的功能与JSON.stringify()和JSON.parse()充分连载数据。
const db = new Dexie('mydb');
db.version(1).stores({friends: '++id,name,age'});
(async()=>{
// Export
const allData = await export (db);
const serialized = JSON.stringify(allData);
// Import
const jsonToImport = '[{"table": "friends", "rows": [{id:1,name:"foo",age:33}]}]';
const dataToImport = JSON.parse(jsonToImport);
await import(dataToImport, db);
})();
扩展自己的页面有其自己的起源。内容脚本使用网页来源。 – wOxxOm