This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
The replaceItem() method of the SVGTransformList interface replaces an existing item in the list with a new item.
The inserted item is the item itself and not a copy.
If newItem is already in a list, it is removed from its previous list before it is inserted into this list.
If the item is already in this list, note that the index of the item to replace is before the removal of the item.
replaceItem(newItem, index)
newItemA SVGTransform item that is inserted into the list.
indexAn integer; the index where the new item should replace the existing one, as an unsigned long.
An SVGTransform object; the inserted item from the list.
This method may raise a DOMException of one of the following types:
NoModificationAllowedError DOMException
Thrown if SVGTransformList corresponds to a read-only attribute or when the object itself is read-only.
IndexSizeError DOMException
Thrown if the index number is greater than or equal to numberOfItems.
<svg width="200" height="200" id="mySvg"> <rect width="100" height="100" fill="blue" transform="translate(50,50)" /> </svg>
const svgElement = document.querySelector("svg");
const rectElement = svgElement.querySelector("rect");
// Access the transform list of the <rect> element
const transformList = rectElement.transform.baseVal;
// Create a new rotation transformation
const rotateTransform = svgElement.createSVGTransform();
rotateTransform.setRotate(45, 50, 50);
transformList.replaceItem(rotateTransform, 0);
// Log the details of the new transformation
console.log(`New Transformation Type: ${transformList.getItem(0).type}`); // Output: 4 (e.g. SVG_TRANSFORM_ROTATE)
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
replaceItem |
1 | 12 | 1.5 | ≤12.1 | 3 | 18 | 4 | ≤12.1 | 1 | 1.0 | 3 | 1 |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/SVGTransformList/replaceItem