WeakSet
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2015.
* Some parts of this feature may have varying levels of support.
Un objet WeakSet
permet de créer un ensemble dont les objets sont contenus avec des références faibles.
Description
Les WeakSet
sont des ensembles d'objets. À l'instar de Set
objet présent dans un objet WeakSet
ne peut apparaître qu'une seule fois, il est unique pour un WeakSet
donné.
Les principales différences avec l'objet Set
sont les suivantes :
-
Contrairement aux
Sets
, lesWeakSets
sont des ensembles uniquement constitués d'objets et ne peuvent pas contenir des valeurs de n'importe quel type. -
L'objet
WeakSet
est faible : les références vers les objets de l'ensemble sont des références faibles. Si aucune autre référence vers l'objet n'est présente en dehors duWeakSet
, l'objet pourra alors être nettoyé par le ramasse-miette.Note : Cela signifie également qu'on ne peut pas lister les objets contenus à un instant donné dans l'ensemble. Les objets
WeakSets
ne sont pas énumérables.
Cas d'usage : détecter les références circulaires
Les fonctions récursives doivent faire attention aux structures de données circulaires qu'elles consommeraient. Les objets WeakSets
peuvent être utilisés pour ça :
// Appeler un callback sur ce qui est stocké dans un objet
function execRecursively(fn, subject, _refs = null) {
if (!_refs) _refs = new WeakSet();
// On évite une récursion infinie
if (_refs.has(subject)) return;
fn(subject);
if ("object" === typeof subject) {
_refs.add(subject);
for (let key in subject) execRecursively(fn, subject[key], _refs);
}
}
const toto = {
toto: "Toto",
truc: {
truc: "Truc",
},
};
toto.truc.machin = toto; // Référence circulaire !
execRecursively((obj) => console.log(obj), toto);
Ici, on a un objet WeakSet
qui est créé lors de la première exécution et qui est passé ensuite à chaque appel qui suit (via l'argument interne _refs
).
Le nombre d'objets ou l'ordre de parcours n'a pas d'importance et un objet WeakSet
est donc plus adapté (y compris en termes de performances) qu'un Set
, notamment si un grand nombre d'objets sont concernés.
Constructeur
WeakSet()
-
Crée un nouvel objet
WeakSet
.
Méthodes des instances
WeakSet.prototype.add(<var>valeur</var>)
-
Ajoute
valeur
à l'ensembleWeakSet
. WeakSet.prototype.delete(<var>valeur</var>)
-
Retire
valeur
de l'ensembleWeakSet
. Suite à cette opération,WeakSet.prototype.has(valeur)
renverrafalse
. WeakSet.prototype.has(<var>valeur</var>)
-
Renvoie un booléen indiquant si
valeur
est présente au sein de l'ensembleWeakSet
.
Exemples
Utiliser un objet WeakSet
const ws = new WeakSet();
const toto = {};
const truc = {};
ws.add(toto);
ws.add(truc);
ws.has(toto); // true
ws.has(truc); // true
ws.delete(toto); // retire toto de l'ensemble
ws.has(toto); // false, toto a été enlevé
ws.has(truc); // toujours true
On notera que toto !== truc
. Bien que ce soient des objets similaires, ce ne sont pas les mêmes objets. Aussi, les deux sont ajoutés à l'ensemble.
Spécifications
Specification |
---|
ECMAScript Language Specification # sec-weakset-objects |
Compatibilité des navigateurs
BCD tables only load in the browser