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="//cdn.jsdelivr.net/jquery/2.1.0/jquery.min.js"></script>
<script src="//cdn.jsdelivr.net/angularjs/1.2.15/angular.min.js"></script>
<script src="//cdn.jsdelivr.net/handlebarsjs/1.3.0/handlebars.js"></script>
<script src="//cdn.jsdelivr.net/mithril/0.1.16/mithril.min.js"></script>
<!-- Angular -->
<div ng-app>
Angular:
<span ng-controller="Ctrl" id="angList">
<span ng-repeat="item in data">{{item}}</span>
</span>
</div>
<!-- Handlebars -->
<div id="hbapp"></div>
<script type="text/x-handlebars" id="hbtemplate">
Handlebars:
<span>
{{#each data}}<span>{{this}}</span>{{/each}}
</span>
</script>
<!-- Mithril -->
<div id="mithrilapp">
Mithril: <span id="mithrilMountNode"></span>
</div>
<script>
var Ctrl = function($scope) { $scope.data = []; };
var MithrilData = [];
var mithapp = {
controller: function() {
this.data = MithrilData;
},
view: function(ctrl) {
return m('span', ctrl.data.map(function(datum) { return m('span', datum); }));
}
}
var HBapp = { data: [] };
$(document).ready(function() {
var ang_scope = $('#angList').scope();
window.ANGclear = function() {
ang_scope.data.splice(0);
ang_scope.$digest();
};
window.ANGpush = function(data) {
ang_scope.data.push(data);
ang_scope.$digest();
}
var hbTmpl = Handlebars.compile($('#hbtemplate').html());
window.HBclear = function() {
HBapp.data.splice(0);
$('#hbapp').html(hbTmpl(HBapp));
}
window.HBpush = function(data) {
HBapp.data.push(data);
$('#hbapp').html(hbTmpl(HBapp));
}
m.module(document.getElementById('mithrilMountNode'), mithapp);
window.Mclear = function() {
MithrilData.splice(0);
m.redraw();
}
window.Mpush = function(data) {
MithrilData.push(data);
m.redraw();
}
});
</script>
Ready to run.
Test | Ops/sec | |
---|---|---|
Angular 10 |
| ready |
Angular 100 |
| ready |
Angular 500 |
| ready |
Handlebars 10 |
| ready |
Handlebars 100 |
| ready |
Handlebars 500 |
| ready |
Mithril 10 |
| ready |
Mithril 100 |
| ready |
Mithril 500 |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.