Get to know MDN better
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Note: This feature is available in Web Workers.
The add() method of the IDBObjectStore interface returns an IDBRequest object, and, in a separate thread, creates a structured clone of the value, and stores the cloned value in the object store. This is for adding new records to an object store.
To determine if the add operation has completed successfully, listen for the transaction's complete event in addition to the IDBObjectStore.add request's success event, because the transaction may still fail after the success event fires. In other words, the success event is only triggered when the transaction has been successfully queued.
The add method is an insert only method. If a record already exists in the object store with the key parameter as its key, then an error ConstraintError event is fired on the returned request object. For updating existing records, you should use the IDBObjectStore.put method instead.
The value to be stored.
key OptionalThe key to use to identify the record. If unspecified, it results to null.
An IDBRequest object on which subsequent events related to this operation are fired.
If the operation is successful, the value of the request's result property is the key for the new record.
This method may raise a DOMException of one of the following types:
ReadOnlyError DOMExceptionThrown if the transaction associated with this operation is in read-only mode.
TransactionInactiveError DOMExceptionThrown if this IDBObjectStore's transaction is inactive.
DataError DOMExceptionThrown if any of the following conditions apply:
Thrown if the IDBObjectStore has been deleted or removed.
DataCloneError DOMExceptionThrown if the data being stored could not be cloned by the internal structured cloning algorithm.
ConstraintError DOMExceptionThrown if an insert operation failed because the primary key constraint was violated (due to an already existing record with the same primary key value).
In the following code snippet, we open a read/write transaction on our database and add some data to an object store using add(). Note also the functions attached to transaction event handlers to report on the outcome of the transaction opening in the event of success or failure. For a full working example, see our To-do Notifications app (view example live).
| Indexed Database API 3.0 # ref-for-dom-idbobjectstore-add① |
Enable JavaScript to view this browser compatibility table.
This page was last modified on Jul 19, 2024 by MDN contributors.
Your blueprint for a better internet.
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998–2026 by individual mozilla.org contributors. Content available under a Creative Commons license.