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
=== SUPER CALL ===
MooTools and Ext Core are removed because they add extra information into native classes. They slow down other libraries.
Ext Core OOP is fast, MooTools OOP is super slow!
TODO: - Add YUI
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/jsface.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/jsface.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/my.class.js"</script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/my.class.js"</script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/jrclass.js"</script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/jrclass.js"</script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/klass.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/klass.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/classy.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/classy.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/ptclass.js"</script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/lib/ptclass.js"</script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/all.js"></script>
<script src="http://dl.dropbox.com/u/7677927/oop-benchmark/all.js"></script>
<script src="https://raw.github.com/IndigoUnited/dejavu/master/dist/regular/loose/dejavu.js"></script>
<script>
var dejavuClassPerson = dejavu.Class({
initialize: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var dejavuClassFrenchGuy = dejavu.Class({
$extends: dejavuClassPerson,
setAddress: function(city, street) {
this.$super("France", city, street);
}
});
var dejavuClassParisLover = dejavu.Class({
$extends: dejavuClassFrenchGuy,
setAddress: function(street) {
this.$super('Paris', street);
}
});
var dejavuSuperAlternativeClassPerson = dejavu.Class({
initialize: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var dejavuSuperAlternativeClassFrenchGuy = dejavu.Class({
$extends: dejavuSuperAlternativeClassPerson,
setAddress: function(city, street) {
dejavuSuperAlternativeClassFrenchGuy .$parent.prototype.setAddress.call(this, "France", city, street);
}
});
var dejavuSuperAlternativeClassParisLover = dejavu.Class({
$extends: dejavuSuperAlternativeClassFrenchGuy,
setAddress: function(street) {
dejavuSuperAlternativeClassParisLover .$parent.prototype.setAddress.call(this, 'Paris', street);
}
});
var p6 = new MyParisLover("Mary");
var p9 = new JRParisLover("Mary");
var p12 = new EnderParisLover("Mary");
var p3 = new JSFaceParisLover("Mary");
var p15 = new ClassyParisLover("Mary");
var p18 = new PTClassParisLover("Mary");
var p19 = new dejavuClassParisLover("Mary");
var p20 = new dejavuSuperAlternativeClassParisLover("Mary");
</script>
Ready to run.
Test | Ops/sec | |
---|---|---|
JSFace |
| ready |
my.Class |
| ready |
John Resig Class |
| ready |
Klass |
| ready |
Classy |
| ready |
PTClass |
| ready |
dejavu |
| ready |
dejavu $super alternative |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.