JavaScript Object Oriented Libraries Benchmark
JavaScript performance comparison
Info
=== FULL TEST ==
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
Preparation code
<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>
Benchmark.prototype.setup = function() {
var JSFacePerson = jsface.Class({
constructor: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var JSFaceFrenchGuy = jsface.Class(JSFacePerson, {
constructor: function(name) {
JSFaceFrenchGuy.$super.call(this, name);
},
setAddress: function(city, street) {
JSFaceFrenchGuy.$superp.setAddress.call(this, 'France', city, street);
}
});
var JSFaceParisLover = jsface.Class(JSFaceFrenchGuy, {
constructor: function(name) {
JSFaceParisLover.$super.call(this, name);
},
setAddress: function(street) {
JSFaceParisLover.$superp.setAddress.call(this, 'Paris', street);
}
});
var p1 = new JSFacePerson("John");
var p2 = new JSFaceFrenchGuy("Leo");
var p3 = new JSFaceParisLover("Mary");
///////////////
var MyPerson = my.Class({
constructor: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var MyFrenchGuy = my.Class(MyPerson, {
constructor: function(name) {
MyFrenchGuy.Super.call(this, name);
},
setAddress: function(city, street) {
MyFrenchGuy.Super.prototype.setAddress.call(this, 'France', city, street);
}
});
var MyParisLover = my.Class(MyFrenchGuy, {
constructor: function(name) {
MyParisLover.Super.call(this, name);
},
setAddress: function(street) {
MyParisLover.Super.prototype.setAddress.call(this, 'Paris', street);
}
});
var p4 = new MyPerson("John");
var p5 = new MyFrenchGuy("Leo");
var p6 = new MyParisLover("Mary");
//////////
var JRPerson = JRClass.extend({
init: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
},
sayHello: function() {
console.log('I am ' + this.name + '. My address is ' +
this.country + ', ' + this.city + ', ' + this.street + '.');
}
});
var JRFrenchGuy = JRPerson.extend({
init: function(name) {
this._super(name);
},
setAddress: function(city, street) {
this._super('France', city, street);
}
});
var JRParisLover = JRFrenchGuy.extend({
init: function(name) {
this._super(name);
},
setAddress: function(street) {
this._super('Paris', street);
}
});
var p7 = new JRPerson("John");
var p8 = new JRFrenchGuy("Leo");
var p9 = new JRParisLover("Mary");
//////////
var EnderPerson = klass(function(name) {
this.name = name;
})
.methods({
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var EnderFrenchGuy = EnderPerson.extend(function(name) {
})
.methods({
setAddress: function(city, street) {
this.supr('France', city, street);
}
});
var EnderParisLover = EnderFrenchGuy.extend(function(name) {
})
.methods({
setAddress: function(street) {
this.supr('Paris', street);
}
});
var p10 = new EnderPerson("John");
var p11 = new EnderFrenchGuy("Leo");
var p12 = new EnderParisLover("Mary");
///////////
var ClassyPerson = Classy.$extend({
__init__: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var ClassyFrenchGuy = ClassyPerson.$extend({
__init__: function(name) {
this.$super(name);
},
setAddress: function(city, street) {
this.$super('France', city, street);
}
});
var ClassyParisLover = ClassyFrenchGuy.$extend({
__init__: function(name) {
this.$super(name);
},
setAddress: function(street) {
this.$super('Paris', street);
}
});
var p13 = new ClassyPerson("John");
var p14 = new ClassyFrenchGuy("Leo");
var p15 = new ClassyParisLover("Mary");
///////////////
var PTClassPerson = PTClass.create({
initialize: function(name){
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var PTClassFrenchGuy = PTClass.create(PTClassPerson, {
initialize: function($super, name) {
$super(name);
},
setAddress: function($super, city, street) {
$super('France', city, street);
}
});
var PTClassParisLover = PTClass.create(PTClassFrenchGuy, {
initialize: function($super, name) {
$super(name);
},
setAddress: function($super, street) {
$super('Paris', street);
}
});
var p16 = new PTClassPerson("John");
var p17 = new PTClassFrenchGuy("Leo");
var p18 = new PTClassParisLover("Mary");
};
</script>
Preparation code output
Test runner
Warning! For accurate results, please disable Firebug before running the tests. (Why?)
Java applet disabled.
| Test | Ops/sec | |
|---|---|---|
JSFace |
|
pending… |
my.Class |
|
pending… |
John Resig Class |
|
pending… |
Klass |
|
pending… |
Classy |
|
pending… |
PTClass |
|
pending… |
Compare results of other browsers
Revisions
You can edit these tests or add even more tests to this page by appending /edit to the URL. Here’s a list of current revisions for this page:
- Revision 3: published by Tan Nhu
- Revision 4: published
- Revision 5: published by Tan Nhu
- Revision 6: published by Tan Nhu
- Revision 7: published by Tan Nhu
- Revision 8: published by Tan Nhu
- Revision 9: published by Tan Nhu
- Revision 10: published by Tan Nhu
- Revision 11: published by André Cruz
- Revision 13: published by André Cruz
- Revision 14: published
- Revision 15: published by Tan Nhu
- Revision 16: published
- Revision 17: published
- Revision 18: published
- Revision 19: published
- Revision 21: published
- Revision 22: published
- Revision 25: published
- Revision 27: published
- Revision 28: published
- Revision 29: published
- Revision 38: published
- Revision 39: published
- Revision 40: published
- Revision 41: published
- Revision 51: published by André Cruz
- Revision 52: published by André Cruz
- Revision 54: published by André Cruz
- Revision 58: published by André Cruz
- Revision 61: published by Nodir Turakulov
- Revision 62: published by Airy
- Revision 64: published
- Revision 69: published
- Revision 70: published by André Cruz
- Revision 77: published by André Cruz
- Revision 79: published by André Cruz
- Revision 83: published
- Revision 84: published by Aadit M Shah
- Revision 85: published by Aadit M Shah
- Revision 86: published by Yuan Tao
- Revision 88: published
- Revision 89: published by Aadit M Shah
- Revision 90: published by Yuan Tao
- Revision 91: published by Aadit M Shah
- Revision 92: published by Yuan Tao
- Revision 93: published by Yuan Tao
- Revision 94: published by Aadit M Shah
- Revision 95: published by Aadit M Shah
- Revision 96: published by Yuan Tao
- Revision 97: published by Aadit M Shah
- Revision 98: published by Yuan Tao
- Revision 100: published by Yuan Tao
- Revision 104: published
- Revision 105: published by Aadit M Shah
- Revision 106: published by Yuan Tao
- Revision 107: published by André Cruz
- Revision 108: published by Aadit M Shah
- Revision 109: published by Mark Johnson
- Revision 110: published by Mark Johnson
- Revision 111: published by Mark Johnson
- Revision 112: published
- Revision 113: published
- Revision 117: published by Aadit M Shah
- Revision 118: published by Aadit M Shah
- Revision 119: published by Yannick Albert and last updated
- Revision 122: published
- Revision 124: published
- Revision 127: published by Aadit M Shah
- Revision 128: published and last updated
- Revision 129: published by Yuan Tao
0 comments