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
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 vonsetImmediate
.
All diese Techniken sind in ein robustes setImmediate-Polyfill integriert.
Spezifikationen
Nicht Teil aktueller Spezifikationen. Die Efficient Script Yielding-Spezifikation wird nicht mehr bearbeitet.