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 und befindet sich nicht auf dem Weg zur Standardisierung. Verwenden Sie sie nicht auf Produktionsseiten, die dem Web ausgesetzt sind: Sie funktioniert nicht für alle Benutzer. Es kann auch 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

Report problems with this compatibility data on GitHub
desktopmobileserver
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
Deno
Node.js
setImmediate
DeprecatedNon-standard

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support
Partial support
Partial support
No support
No support
Non-standard. Check cross-browser support before using.
Deprecated. Not for use in new websites.

Siehe auch