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
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.
Browser-Kompatibilität
BCD tables only load in the browser