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
Is it faster to use the native forEach or just loop with for?
Inspired by Adrian Sutton's tests at: http://www.symphonious.net/2010/10/09/javascript-performance-for-vs-foreach/
This one adds random floating point numbers to see if the loop overhead is significant at all in the face of standard work. And, a worst-case for loop with an un-cached length counter.
<script src="http://code.jquery.com/jquery-1.8.2.min.js">
</script>
var i,
value,
length,
values = [],
sum = 0,
context = values;
for (i = 0; i < 10000; i++) {
values[i] = Math.random();
}
function add(val) {
sum += val;
}
function addEach(k, val) {
sum += val;
}
var toString = Object.prototype.toString;
function isArray(obj) {
return toString.call(obj) === '[object Array]';
}
function isObject(obj) {
return toString.call(obj) === '[object Object]';
}
function isString(obj) {
return toString.call(obj) === '[object String]';
}
function each(obj, iterator) {
var key, length;
if (!obj) {
return;
}
length = obj.length;
if (isArray(obj) || isString(obj)) {
for(key = 0; key < length; key += 1) {
iterator(obj[key], key, obj);
}
return obj;
}
if (isObject(obj)) {
for(key in obj) {
if (obj.hasOwnProperty(key)) {
iterator(obj[key], key, obj);
}
}
return obj;
}
return obj;
};
i = 0;
value = 0;
length = 0;
values = [];
sum = 0;
Ready to run.
Test | Ops/sec | |
---|---|---|
forEach |
| ready |
for loop, cached length, callback |
| ready |
for loop, cached length, callback.call |
| ready |
$.each |
| ready |
for loop, assignment condition, callback |
| ready |
for loop, assignment condition, callback.call |
| ready |
native map function |
| ready |
new each |
| ready |
for loop, un-cached length, callback |
| ready |
for loop, cached length in loop, |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.