Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Creating elements with cloneNode (template vs. normal element)
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (iPhone; CPU iPhone OS 17_6_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/17.6 Mobile/15E148 Safari/604.1
Browser:
Mobile Safari 17
Operating system:
iOS 17.6.1
Device Platform:
Mobile
Date tested:
one year ago
Test name
Executions per second
Simple - Template
2553033.8 Ops/sec
Simple - JavaScript
3902862.0 Ops/sec
Complex - Template
523063.8 Ops/sec
Complex - JavaScript
869621.0 Ops/sec
Script Preparation code:
var simpleTemplate = document.createElement("template"); simpleTemplate.innerHTML = `<span class="simple"></span>`; var complexTemplate = document.createElement("template"); complexTemplate.innerHTML = `<span class="complex"> <span class="simple-1"></span> <span class="simple-2"> <span class="simple-2-1"></span> </span> <span class="simple-3"> <span class="simple-3-1"></span> </span> <span class="simple-4"></span> </span>`; var simpleElement = document.createElement("span"); simpleElement.classList.add("simple"); var complexElement = document.createElement("span"); complexElement.classList.add("complex"); complexElement.innerHTML = `<span class="simple-1"></span> <span class="simple-2"> <span class="simple-2-1"></span> </span> <span class="simple-3"> <span class="simple-3-1"></span> </span> <span class="simple-4"></span>`;
Tests:
Simple - Template
let el = document.createElement("div"); let content = simpleTemplate.content.cloneNode(true); el.appendChild(content);
Simple - JavaScript
let el = document.createElement("div"); let content = simpleElement.cloneNode(true); el.appendChild(content);
Complex - Template
let el = document.createElement("div"); let content = complexTemplate.content.cloneNode(true); el.appendChild(content);
Complex - JavaScript
let el = document.createElement("div"); let content = complexElement.cloneNode(true); el.appendChild(content);