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
Testing if the perf hit for Object.keys(..).forEach(..)
is enough to matter as compared to for-in
.
<script>
// pre-ES5 polyfill for Object.keys()
Object.keys=Object.keys||function(o,k,r){r=[];for(k in o)r.hasOwnProperty.call(o,k)&&r.push(k);return r}
// pre-ES5 polyfill for Array.prototype.forEach()
Array.prototype.forEach||(Array.prototype.forEach=function(a,b){for(var c=0,d=this.length;d>c;++c)a.call(b,this[c],c,this)});
function iterate1() {
var ret = "", i = 0;
for (i in obj) {
ret += obj[i];
}
return ret;
}
function iterate2() {
var ret = "", i = 0;
Object.keys(obj).forEach(function(key){
ret += obj[key];
});
}
function iterate3() {
var ret = "", i = 0;
var keys = Object.keys(obj);
for (var i = 0; i < keys.length; i++) {
ret += obj[keys[i]];
};
}
// object with 10 keys in it
var obj = {
a: "a",
b: "b",
c: "c",
d: "d",
e: "e",
f: "f",
g: "g",
h: "h",
i: "i",
j: "j"
};
delete obj.a; //force deoptimization
var tmp;
</script>
tmp = "";
Ready to run.
Test | Ops/sec | |
---|---|---|
for-in |
| ready |
Object.keys(..).forEach(..) |
| ready |
Object.keys for loop |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.