This is a fork of idb-keyval
.
A super simple key value store backed by IndexedDB.
Since it is backed by IndexedDB, you can store anything structured-clonable (numbers, arrays, objects, dates, blobs etc - but beware of browser support).
It's best used with a module loader (webpack, browserify, etc...) so that the global scope isn't poluted with kv
.
Creates a custom kv store with a given name.
const store = kv('sw-storage');
await store.set('hello', 'world');
console.log(await kv.get('hello'));
// -> undefined
await kv.set('hello', 'world');
await kv.set('foo', 'bar');
try {
await kv.set('hello', 'world')
console.log('It worked!');
} catch(err) {
console.log('It failed!', err);
}
console.log(await kv.get('hello'));
// -> "world"
console.log(await kv.keys());
// -> ["hello", "foo"]
await kv.remove('hello');
await kv.clear();
That's it!