structuredClone()
The global structuredClone()
method creates a deep clone of a given value using the structured clone algorithm.
The method also allows transferable objects in the original value to be transferred rather than cloned to the new object. Transferred objects are detached from the original object and attached to the new object; they are no longer accessible in the original object.
Syntax
structuredClone(value) structuredClone(value, { transfer })
Parameters
value
-
The object to be cloned. This can be any structured-clonable type.
-
transfer
Optional -
A array of transferable objects in
value
that will be moved rather than cloned to the returned object.
Return value
The returned value is a deep copy of the original value
.
Exceptions
-
DataCloneError
DOMException
-
Thrown if any part of the input value is not serializable.
Description
This function can be used to deep copy JavaScript values. It also supports circular references, as shown below:
// Create an object with a value and a circular reference to itself. const original = { name: "MDN" }; original.itself = original; // Clone it const clone = structuredClone(original); console.assert(clone !== original); // the objects are not the same (not same identity) console.assert(clone.name === "MDN"); // they do have the same values console.assert(clone.itself === clone); // and the circular reference is preserved
Transfering values
Transferable objects (only) can be transferred rather than duplicated in the cloned object, using the optional parameter's transfer
value. Transferring makes the original object unusable.
Note: A scenario where this might be useful is when asynchronously validating some data in a buffer before saving it. To avoid the buffer being modified before the data is saved, you can clone the buffer and validate that data. If you also transfer the data, any attempts to modify the original buffer will fail, preventing its accidental misuse.
The following code shows how to clone an array and transfer its underlying resources to the new object. On return, the original uInt8Array.buffer
will be cleared.
var uInt8Array = new Uint8Array(1024 * 1024 * 16); // 16MB for (var i = 0; i < uInt8Array.length; ++i) { uInt8Array[i] = i; } const transferred = structuredClone(uInt8Array, { transfer: [uInt8Array.buffer] }). console.log(uInt8Array.byteLength); // 0
You can clone any number of objects and transfer any subset of those objects. For example, the code below would transfer arrayBuffer1
from the passed in value, but not arrayBuffer2
.
const transferred = structuredClone( { x: { y: { z: arrayBuffer1, w: arrayBuffer2 } } }, { transfer: [arrayBuffer1] });
Specifications
Specification |
---|
HTML Standard (HTML) # dom-structuredclone |
Browser compatibility
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
structuredClone |
No |
No |
94 |
No |
No |
No |
No |
No |
94 |
No |
No |
No |
worker_support |
No |
No |
94 |
No |
No |
No |
No |
No |
94 |
No |
No |
No |
See also
© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/structuredClone