Der Algorithmus für das strukturierte Klonen
Der Algorithmus für das strukturierte Klonen kopiert komplexe JavaScript-Objekte. Er wird intern verwendet, wenn structuredClone()
aufgerufen wird, um Daten zwischen Arbeitern (Workers) über postMessage()
zu übertragen, Objekte mit IndexedDB zu speichern oder Objekte für andere APIs zu kopieren.
Er klont, indem er das Eingabeobjekt rekursiv durchläuft und eine Karte der zuvor besuchten Referenzen führt, um ein unendliches Durchlaufen von Zyklen zu vermeiden.
Dinge, die nicht mit strukturiertem Klonen funktionieren
Function
-Objekte können nicht vom Algorithmus für das strukturierte Klonen dupliziert werden; bei einem Versuch wird eineDataCloneError
-Ausnahme ausgelöst.- Das Klonen von DOM-Knoten führt ebenfalls zu einer
DataCloneError
-Ausnahme. - Bestimmte Objekteigenschaften werden nicht beibehalten:
- Die
lastIndex
-Eigenschaft vonRegExp
-Objekten wird nicht beibehalten. - Eigenschaftsdescriptoren, Setter, Getter und ähnliche metadatenartige Funktionen werden nicht dupliziert. Zum Beispiel, wenn ein Objekt mit einem Eigenschaftsdeskriptor schreibgeschützt markiert ist, wird es in der Kopie als lesbar/schreibbar dargestellt, da dies der Standard ist.
- Die Prototypenkette wird nicht durchlaufen oder dupliziert.
- Private Klassen-Eigenschaften werden nicht dupliziert. (Obwohl private Eigenschaften eingebauter Typen möglicherweise dupliziert werden.)
- Die
Unterstützte Typen
JavaScript-Typen
Array
ArrayBuffer
Boolean
DataView
Date
Error
-Typen (siehe unten Fehlertypen).Map
Number
Object
-Objekte: aber nur einfache Objekte (z. B. von Objektliteralen).- Primitive Typen, außer
symbol
. RegExp
: aber beachten Sie, dasslastIndex
nicht beibehalten wird.Set
String
TypedArray
Fehlertypen
Für Error
-Typen muss der Fehlername einer der folgenden sein: Error
, EvalError
, RangeError
, ReferenceError
, SyntaxError
, TypeError
, URIError
(oder wird auf "Error" gesetzt).
Browser müssen die Eigenschaften name
und message
serialisieren und sollen auch andere "interessante" Eigenschaften der Fehler wie stack
, cause
usw. serialisieren.
Unterstützung für AggregateError
wird erwartet, dass sie in die Spezifikation in whatwg/html#5749 aufgenommen wird (und wird bereits in einigen Browsern unterstützt).
Web/API-Typen
AudioData
Blob
CropTarget
CryptoKey
DOMException
: Browser müssen die Eigenschaftenname
undmessage
serialisieren. Andere Attribute können ebenfalls serialisiert/gekoppelt werden.DOMMatrix
DOMMatrixReadOnly
DOMPoint
DOMPointReadOnly
DOMQuad
DOMRect
DOMRectReadOnly
EncodedAudioChunk
EncodedVideoChunk
FencedFrameConfig
File
FileList
FileSystemDirectoryHandle
FileSystemFileHandle
FileSystemHandle
GPUCompilationInfo
GPUCompilationMessage
GPUPipelineError
ImageBitmap
ImageData
RTCCertificate
RTCEncodedAudioFrame
RTCEncodedVideoFrame
VideoFrame
WebTransportError
Hinweis:
Serialisierbare Objekte sind in Web IDL-Dateien mit dem Attribut [Serializable]
gekennzeichnet.