aboutsummaryrefslogtreecommitdiff
path: root/files/fr/web/api/idbobjectstore/getallkeys/index.md
blob: df2f4b69ceed283096d574b5ba004066f890b61d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
---
title: IDBObjectStore.getAllKeys()
slug: Web/API/IDBObjectStore/getAllKeys
tags:
  - API
  - IDBObjectStore
  - IndexedDB
  - Méthode
  - Référence(2)
translation_of: Web/API/IDBObjectStore/getAllKeys
---
{{APIRef("IndexedDB")}}

La méthode **`getAllKeys()`**, rattachée à l'interface {{domxref("IDBObjectStore")}}, renvoie un objet  {{domxref("IDBRequest")}} qui permet de récupérer l'ensemble des clés pour les objets qui correspondent au critère passé en argument (ou les clés de tous les objets du magasin si aucun paramètre n'est fourni).

Si une valeur est trouvée, un clone structurelle sera créé et fourni comme résultat pour la requête.

Cette méthode produira le même résultat pour :

- un enregistrement qui n'existe pas dans la base de données
- un enregistrement qui possède une valeur indéfinie

Pour différencier ces deux situations, on peut appeler la méthode {{domxref("IDBObjectStore.openCursor","openCursor()")}} avec la même clé. Cette méthode fournit un curseur si l'enregistrement existe et ne fournit aucun curseur s'il n'y a pas d'enregistrement.

## Syntaxe

    var request = objectStore.getAllKeys();
    var request = objectStore.getAllKeys(query);
    var request = objectStore.getAllKeys(query, count);

### Parameters

- `query` {{optional_inline}}
  - : Une valeur qui est (ou se résoud) en un intervalle de clés ({{domxref("IDBKeyRange")}}).
- `count` {{optional_inline}}
  - : Une valeur qui définit le nombre de valeurs à renvoyer si plusieurs correspondent. Cette valeur doit être supérieure à  `0` ou inférieure `à 2^32-1`, sinon une exception {{jsxref("TypeError")}} sera levée.

### Valeur de retour

Un objet {{domxref("IDBRequest")}} pour lequel seront déclenchés les différents évènements relatifs à l'opération.

### Exceptions

Cette méthode peut déclencher une exception {{domxref("DOMException")}} ayant le type suivant :

<table class="standard-table">
  <thead>
    <tr>
      <th scope="col">Exception</th>
      <th scope="col">Description</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td><code>TransactionInactiveError</code></td>
      <td>
        Le magasin d'objets ({{domxref("IDBObjectStore")}}) associé à
        la transaction est inactif.
      </td>
    </tr>
    <tr>
      <td><code>DataError</code></td>
      <td>
        <p>
          La clé ou l'intervalle de clé fourni contient une clé invalide ou est
          nul.
        </p>
      </td>
    </tr>
    <tr>
      <td><code>InvalidStateError</code></td>
      <td>
        Le magasin d'objets ({{domxref("IDBObjectStore")}}) a été
        supprimé ou retiré.
      </td>
    </tr>
  </tbody>
</table>

## Spécifications

| Spécification                                                                                    | État                             | Commentaires         |
| ------------------------------------------------------------------------------------------------ | -------------------------------- | -------------------- |
| {{SpecName('IndexedDB 2', '#dom-idbobjectstore-getallkeys', 'getAll()')}} | {{Spec2('IndexedDB w')}} | Définition initiale. |

## Compatibilité des navigateurs

{{Compat("api.IDBObjectStore.getAllKeys")}}

## Voir aussi

- [Utiliser IndexedDB](/fr/docs/Web/API/API_IndexedDB/Using_IndexedDB)
- Initier une connexion : {{domxref("IDBDatabase")}}
- Utiliser les transactions : {{domxref("IDBTransaction")}}
- Définir un intervalle de clés : {{domxref("IDBKeyRange")}}
- Récupérer et modifier les données : {{domxref("IDBObjectStore")}}
- Utiliser les curseurs {{domxref("IDBCursor")}}
- Exemple de référence : [To-do Notifications](https://github.com/mdn/to-do-notifications/tree/gh-pages) ([exemple _live_](https://mdn.github.io/to-do-notifications/)).