Window: setImmediate()-Methode

Veraltet: Diese Funktion wird nicht mehr empfohlen. Obwohl einige Browser sie möglicherweise noch unterstützen, könnte sie bereits aus den relevanten Webstandards entfernt worden sein, in Kürze entfernt werden oder nur noch aus Kompatibilitätsgründen bestehen. Vermeiden Sie die Verwendung und aktualisieren Sie vorhandenen Code, falls möglich; siehe die Kompatibilitätstabelle am Ende dieser Seite, um Ihre Entscheidung zu unterstützen. Beachten Sie, dass diese Funktion jederzeit aufhören könnte zu funktionieren.

Nicht standardisiert: Diese Funktion ist nicht standardisiert. Wir raten davon ab, nicht-standardisierte Funktionen auf produktiven Webseiten zu verwenden, da sie nur von bestimmten Browsern unterstützt werden und sich in Zukunft ändern oder entfernt werden können. Unter Umständen kann sie jedoch eine geeignete Option sein, wenn es keine standardisierte Alternative gibt.

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

Siehe auch