Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

Map.prototype.getOrInsert()

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.

Die getOrInsert()-Methode von Map-Instanzen gibt den Wert zurück, der dem angegebenen Schlüssel in dieser Map entspricht. Ist der Schlüssel nicht vorhanden, fügt sie einen neuen Eintrag mit dem Schlüssel und einem angegebenen Standardwert ein und gibt den eingefügten Wert zurück.

Wenn die Berechnung des Standardwerts aufwendig ist, ziehen Sie stattdessen Map.prototype.getOrInsertComputed() in Betracht, das einen Callback verwendet, um den Standardwert nur dann zu berechnen, wenn er tatsächlich benötigt wird.

Probieren Sie es aus

const map = new Map([["bar", "foo"]]);
console.log(map.getOrInsert("bar", "default"));
// Expected output: "foo"

console.log(map.getOrInsert("baz", "default"));
// Expected output: "default"

Syntax

js
getOrInsert(key, defaultValue)

Parameter

key

Der Schlüssel des Werts, der aus dem Map-Objekt zurückgegeben werden soll. Objekt-Schlüssel werden nach Referenz und nicht nach Wert verglichen.

defaultValue

Der Wert, der eingefügt und zurückgegeben wird, wenn der Schlüssel im Map-Objekt noch nicht vorhanden ist.

Rückgabewert

Der Wert, der dem angegebenen Schlüssel im Map-Objekt zugeordnet ist. Wenn der Schlüssel nicht gefunden werden kann, wird defaultValue eingefügt und zurückgegeben.

Beschreibung

Die getOrInsert()-Methode ist äquivalent zu folgendem:

js
if (map.has(key)) {
  return map.get(key);
}
map.set(key, defaultValue);
return defaultValue;

Sie ähnelt auch dem folgenden Muster (das etwas weniger zuverlässig ist, wenn null oder undefined gültige Werte in Ihrer Map sind):

js
map.set(key, map.get(key) ?? defaultValue);

Beispiele

Anwendung von Standardwerten

Sie können getOrInsert() verwenden, um sicherzustellen, dass ein Schlüssel in einer Map existiert, auch wenn Sie seinen Wert derzeit nicht benötigen. Dies dient normalerweise zur Normalisierung von Benutzereingaben.

Stellen Sie sich vor, Sie haben eine Map mit Benutzerpräferenzen und möchten sicherstellen, dass eine bestimmte Präferenz immer auf einen Standardwert gesetzt wird, wenn der Benutzer sie nicht angegeben hat:

js
const options = readConfig();
options.getOrInsert("theme", "light");
options.getOrInsert("fontSize", 14);

// Later in your code, you can safely assume these options exist
document.body.dataset.theme = options.get("theme");

Spezifikationen

Specification
Upsert
# sec-map.prototype.getOrInsert

Browser-Kompatibilität

Siehe auch