Window: setImmediate()-Methode

Veraltet: Diese Funktion wird nicht mehr empfohlen. Obwohl einige Browser sie möglicherweise noch unterstützen, kann sie bereits aus den relevanten Webstandards entfernt worden sein, befindet sich im Prozess der Entfernung oder wird nur aus Kompatibilitätsgründen beibehalten. Vermeiden Sie die Verwendung und aktualisieren Sie gegebenenfalls bestehenden Code; siehe die Kompatibilitätstabelle am Ende dieser Seite, um Ihre Entscheidung zu treffen. Beachten Sie, dass diese Funktion jederzeit nicht mehr funktionieren kann.

Kein Standard: Diese Funktion ist nicht standardisiert und befindet sich nicht im Standardisierungsprozess. Verwenden Sie sie nicht auf Produktionsseiten, die auf das Web ausgerichtet sind: Sie wird nicht für alle Benutzer funktionieren. Außerdem kann es große Inkompatibilitäten zwischen Implementierungen geben und das Verhalten kann sich in Zukunft ändern.

Diese Methode wird verwendet, um lang andauernde Operationen aufzuteilen und eine Callback-Funktion unmittelbar auszuführen, nachdem der Browser andere Operationen wie Ereignisse und Anzeigeaktualisierungen abgeschlossen hat.

Syntax

js
setImmediate(func)
setImmediate(func, param1)
setImmediate(func, param1, param2)
setImmediate(func, param1, param2, /* …, */ paramN)

Parameter

func

Die Funktion, die Sie aufrufen möchten.

param1, …, paramN

Alle Parameter werden direkt an Ihre Funktion übergeben.

Rückgabewert

Die ID der sofortigen Ausführung, die später mit window.clearImmediate verwendet werden kann.

Hinweise

Die clearImmediate()-Methode kann verwendet werden, um die sofortigen Aktionen zu löschen, genau wie clearTimeout() für setTimeout().

Diese Methode kann anstelle von setTimeout(fn, 0) verwendet werden, um aufwändige Operationen auszuführen.

Das Feature kann auf verschiedene Weise emuliert werden:

  • postMessage() kann verwendet werden, um einen unmittelbaren, aber verzögernden Callback auszulösen.
  • MessageChannel kann zuverlässig innerhalb von Web Workers verwendet werden, während die Semantik von postMessage bedeutet, dass es dort nicht verwendet werden kann.
  • setTimeout(fn, 0) kann potenziell verwendet werden, jedoch da es gemäß der HTML-Spezifikation auf 4ms für mehr als 5 Ebenen tief verschachtelte Timer begrenzt ist, ist es kein geeigneter Ersatz für die natürliche Unmittelbarkeit von setImmediate.

All diese Techniken sind in ein robustes setImmediate-Polyfill integriert.

Spezifikationen

Nicht Teil aktueller Spezifikationen. Die Efficient Script Yielding-Spezifikation wird nicht mehr bearbeitet.

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch