Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Setting SVG transform attribute
Use SVGTransform API vs setAttribute()
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/18.3.1 Safari/605.1.15
Browser:
Safari 18
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
el.setAttribute
3428747.0 Ops/sec
el.transform.baseVal.appendItem
1926585.6 Ops/sec
HTML Preparation code:
<svg id="svg"><g id="node"/></svg>
Script Preparation code:
const node = document.getElementById('node'); const svg = document.getElementById('svg'); const matrix = svg.createSVGMatrix(); matrix.a = 2; matrix.d = 2; function matrixToTransformString(matrix) { return `matrix(${matrix.a}, ${matrix.b}, ${matrix.c}, ${matrix.d}, ${matrix.e}, ${matrix.f})`; }
Tests:
el.setAttribute
node.setAttribute('transform', matrixToTransformString(matrix));
el.transform.baseVal.appendItem
const transform = svg.createSVGTransform(); transform.setMatrix(matrix); const transformList = node.transform.baseVal; if (transformList.numberOfItems > 0) { transformList.clear(); } transformList.appendItem(transform);