IDBRequest.transaction
Baseline
Widely available
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
Note : Cette fonctionnalité est disponible via les Web Workers.
La propriété transaction en lecture seule de l'interface IDBRequest renvoie la transaction pour la requête, c'est-à-dire la transaction dans laquelle la requête est effectuée.
Cette propriété peut être null pour les requêtes non effectuées dans des transactions, comme pour les requêtes renvoyées par IDBFactory.open — dans ce cas, vous vous connectez simplement à une base de données, donc il n'y a pas de transaction à renvoyer. Si une mise à niveau de version est nécessaire lors de l'ouverture d'une base de données, alors pendant le gestionnaire d'événements upgradeneeded, la propriété transaction sera une IDBTransaction avec mode égal à "versionchange", et peut être utilisée pour accéder aux magasins d'objets et index existants, ou annuler la mise à niveau. Après la mise à niveau, la propriété transaction sera à nouveau null.
Valeur
Une IDBTransaction.
Exemple
L'exemple suivant demande un titre d'enregistrement donné, onsuccess obtient l'enregistrement associé du magasin d'objects (mis à disposition en tant que objectStoreTitleRequest.result), on met à jour une propriété de l'enregistrement, puis le sauve dans le magasin d'objects. La transaction à l'origine de la deuxième requête est affichée sur la console du développeur (Ps, les deux requêtes proviennent de la même transaction). En bas est une fonction onerror qui affiche le code d'erreur si la requête échoue. Pour un exemple de travail complet, voir notre application Notifications des tâches à faire (angl.) (voir l'exemple en direct).
const title = "Chien de garde";
// Ouvrez une transaction comme d'habitude
const objectStore = db
.transaction(["listeDeTaches"], "readwrite")
.objectStore("listeDeTaches");
// Obtenez l'objet "listeDeTaches" qui a ce titre
const objectStoreTitleRequest = objectStore.get(title);
objectStoreTitleRequest.onsuccess = () => {
// Prenez l'objet de données renvoyé comme résultat
const data = objectStoreTitleRequest.result;
// Mettre à jour la valeur notified de l'objet à "oui"
data.notified = "oui";
// Créer une autre requête qui insère le nouvelle élément dans la base de données
const updateTitleRequest = objectStore.put(data);
// Affiche la transaction à l'origine de la deuxième requête
console.log(
" la transaction à l'origine de ces requêtes est " +
updateTitleRequest.transaction,
);
// Lorsque cette requête réussit, appelle de la fonction displayData() pour
// mettre à jour l'affichage
updateTitleRequest.onsuccess = () => {
displayData();
};
};
Cet exemple montre comment la propriété transaction peut être utilisé pendant une mise à niveau de version pour accéder à des magasins d'objects existants :
const openRequest = indexedDB.open("db", 2);
console.log(openRequest.transaction); // Affiche "null".
openRequest.onupgradeneeded = (event) => {
console.log(openRequest.transaction.mode); // Affiche "versionchange".
const db = openRequest.result;
if (event.oldVersion < 1) {
// Nouvelle base de données, créer un magasin d'objets "livres".
db.createObjectStore("livres");
}
if (event.oldVersion < 2) {
// Mise à niveau de la base de données v1: ajoute un index sur "titre"
// pour stocker les livres.
const bookStore = openRequest.transaction.objectStore("livres");
bookStore.createIndex("par_titre", "titre");
}
};
openRequest.onsuccess = () => {
console.log(openRequest.transaction); // Affiche "null".
};
Spécifications
| Specification |
|---|
| Indexed Database API 3.0> # ref-for-dom-idbrequest-transaction①> |
Compatibilité des navigateurs
Chargement…
Voir aussi
- Utiliser IndexedDB
- Démarrer des transactions :
IDBDatabase - Utiliser des transactions :
IDBTransaction - Définir une plage de clés :
IDBKeyRange - Récupérer et modifier vos données :
IDBObjectStore - Utiliser des curseurs :
IDBCursor - Exemple de référence : Notifications des tâches à faire (angl.) (Voir l'exemple en direct).