jsPerf.app is an online JavaScript performance benchmark test runner & jsperf.com mirror. It is a complete rewrite in homage to the once excellent jsperf.com now with hopefully a more modern & maintainable codebase.
jsperf.com URLs are mirrored at the same path, e.g:
https://jsperf.com/negative-modulo/2
Can be accessed at:
https://jsperf.app/negative-modulo/2
<div style="width:1px;height:1px;overflow:hidden;">
<div id='box1'></div>
<div id='box2'></div>
<div id='box3'></div>
<div id='box4'></div>
</div>
var testPattern = '<div>hello<div style="background-color: #000000;">ttt</div></div>';
var i, testString;
for (i = 0; i < 1000; i++) {
testString += testPattern;
}
var box1 = document.getElementById('box1');
var box2 = document.getElementById('box2');
var box3 = document.getElementById('box3');
var box4 = document.getElementById('box4');
box1.innerHTML = testString;
box2.innerHTML = testString;
box3.innerHTML = testString;
box4.innerHTML = testString;
function test1() {
if (!box1) return;
while (box1.firstChild) {
box1.removeChild(box1.firstChild);
}
box1 = null;
}
function test2() {
if (!box2) return;
while (box2.lastChild) {
box2.removeChild(box2.firstChild);
}
box2 = null;
}
function test3() {
if (!box3) return;
var parent = box3.parentNode;
parent.removeChild(box3);
box3.innerHTML = '';
parent.appendChild(box3);
box3 = null;
}
function test4() {
if (!box4) return;
var parent = box4.parentNode;
parent.replaceChild(box4.cloneNode(false), box4);
box4 = null;
}
function test5() {
if (!box3) return;
box3.innerHTML = '';
}
Ready to run.
Test | Ops/sec | |
---|---|---|
innerHTML |
| ready |
replaceChild |
| ready |
removeChild (first) |
| ready |
innerHTML inside DOM |
| ready |
removeChild (last) |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.