RxStorage Dexie.js
To store the data inside of IndexedDB in the browser, you can use the Dexie.js RxStorage. Dexie.js is a minimal wrapper around IndexedDB and the Dexie.js RxStorage wraps that again to store RxDB data in the browser. For side projects and prototypes that run in a browser, you should use the dexie RxStorage as a default. For professional projects that care about performance and stability, use the IndexedDB RxStorage instead.
Pros
- Can use Dexie.js addons.
Limitations
- Does not allow to use non-required fields as index, because that is not possible with dexie.js. Use the IndexedDB RxStorage if you need that.
- Does not use a Batched Cursor or custom indexes which makes queries slower compared to the IndexedDB RxStorage.
- Does not support the Storage Buckets API
Performance comparison with other RxStorage plugins
The performance of the Dexie.js RxStorage is good enough for most use cases but other storages can have way better performance metrics:
Usage
import { createRxDatabase } from 'rxdb/plugins/core';
import { getRxStorageDexie } from 'rxdb/plugins/storage-dexie';
const db = await createRxDatabase({
name: 'exampledb',
storage: getRxStorageDexie()
});
Overwrite/Polyfill the native IndexedDB
Node.js has no IndexedDB API. To still run the Dexie RxStorage
in Node.js, for example to run unit tests, you have to polyfill it.
You can do that by using the fake-indexeddb module and pass it to the getRxStorageDexie()
function.
import { createRxDatabase } from 'rxdb/plugins/core';
import { getRxStorageDexie } from 'rxdb/plugins/storage-dexie';
//> npm install fake-indexeddb --save
const fakeIndexedDB = require('fake-indexeddb');
const fakeIDBKeyRange = require('fake-indexeddb/lib/FDBKeyRange');
const db = await createRxDatabase({
name: 'exampledb',
storage: getRxStorageDexie({
indexedDB: fakeIndexedDB,
IDBKeyRange: fakeIDBKeyRange
})
});
Using addons
Dexie.js has its own plugin system with many plugins for encryption, replication or other use cases. With the Dexie.js RxStorage
you can use the same plugins by passing them to the getRxStorageDexie()
function.
const db = await createRxDatabase({
name: 'exampledb',
storage: getRxStorageDexie({
addons: [ /* Your Dexie.js plugins */ ]
})
});
Disabling the non-premium console log
We want to be transparent with our community, and you'll notice a console message when using the free Dexie.js based RxStorage implementation. This message serves to inform you about the availability of faster storage solutions within our 👑 Premium Plugins. We understand that this might be a minor inconvenience, and we sincerely apologize for that. However, maintaining and improving RxDB requires substantial resources, and our premium users help us ensure its sustainability. If you find value in RxDB and wish to remove this message, we encourage you to explore our premium storage options, which are optimized for professional use and production environments. Thank you for your understanding and support.
If you already have premium access and want to use the Dexie.js RxStorage without the log, you can call the setPremiumFlag()
function to disable the log.
import { setPremiumFlag } from 'rxdb-premium/plugins/shared';
setPremiumFlag();