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 src="https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
$.fn.measureWidth = function(params) {
params = params || {};
var span = document.createElement('span');
if (params.hide) span.style.visibility = "hidden";
span.style.whiteSpace = "nowrap";
span.style.margin = span.style.padding = 0;
span.innerHTML = this.outerHTML;
document.body.appendChild(span);
var width = span.offsetWidth;
document.body.removeChild(span);
return width;
}
$.fn.canvasMeasureWidth = function() {
if (!jQuery._cacheCanvas) {
var canvas = document.createElement('canvas');
var docFragment = document.createDocumentFragment();
docFragment.appendChild(canvas);
jQuery._cacheCanvas = canvas;
}
return jQuery._cacheCanvas.getContext("2d").measureText(text).width;;
}
var text = "YOU SHALL NOT PASS!";
Ready to run.
Test | Ops/sec | |
---|---|---|
Check width on not hidden |
| ready |
The same with hidden |
| ready |
Cached canvas |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.