Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Overriding 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/537.36 (KHTML, like Gecko) Chrome/135.0.0.0 Safari/537.36
Browser:
Chrome 135
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
el.setAttribute
2933364.2 Ops/sec
el.transform.baseVal.appendItem
3426995.0 Ops/sec
HTML Preparation code:
<svg id="svg"><g id="node" transform="translate(10, 10) scale(20, 20)"/></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);