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
<script>
var i,
arr = [],
sum = 0
for (i = 0; i < 10000; i++) {
arr[i] = Math.random();
}
</script>Array.prototype.my_forEach = function(f) {
for (var k = -1, m = this.length; ++k < m;)
if (k in this) f(this[k], k, this)
}
var my_forEach = function(A, f) {
for (var k = 0, m = A.length; k < m; k++)
if (k in A) f(A[k], k, A)
}Ready to run.
| Test | Ops/sec | |
|---|---|---|
| while loop that imitates a for loop | | ready |
| while loop that imitates a for loop, caching the length | | ready |
| Reverse while loop | | ready |
| Reverse while loop without implicit ToBoolean | | ready |
| Reverse do … while loop | | ready |
| Reverse for loop | | ready |
| Old ’n’ busted for loop | | ready |
| Old ’n’ busted for loop, caching the length | | ready |
| Cool guy loop | | ready |
| Cool guy loop, caching the length | | ready |
| Native Array#forEach implementation | | ready |
| Native Array#forEach implementation with named function | | ready |
| perso implement | | ready |
| perso2 | | ready |
| Recursion with shift | | ready |
| Recursion with pop | | ready |
| Closure recursion with shift | | ready |
| Closure recursion with pop | | ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.