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
=== 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
<script src="https://raw.github.com/tnhu/jsface/master/jsface.js"></script>
<script src="https://raw.github.com/jiem/my-class/master/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/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/ptclass.js"></script>
<script src="https://raw.github.com/javascript/augment/master/augment.js"></script>
<script src="http://cdn.sencha.com/ext-4.1.1a-gpl/builds/ext-foundation.js"></script>
<script src="https://raw.github.com/torworx/oxygen.js/master/oxygen.js"></script>
<script>
var __hasProp = {}.hasOwnProperty,
__extends = function(child, parent) {
for (var key in parent) {
if (__hasProp.call(parent, key)) child[key] = parent[key];
}
function ctor() {
this.constructor = child;
}
ctor.prototype = parent.prototype;
child.prototype = new ctor();
child.__super__ = parent.prototype;
return child;
};
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 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 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 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 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 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 CoffeePerson = (function() {
function CoffeePerson(name) {
this.name = name;
}
CoffeePerson.prototype.setAddress = function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
};
return CoffeePerson;
})();
var CoffeeFrenchGuy = (function(_super) {
__extends(CoffeeFrenchGuy, _super);
function CoffeeFrenchGuy(name) {
CoffeeFrenchGuy.__super__.constructor.call(this, name);
}
CoffeeFrenchGuy.prototype.setAddress = function(city, street) {
return CoffeeFrenchGuy.__super__.setAddress.call(this, "France", city, street);
};
return CoffeeFrenchGuy;
})(CoffeePerson);
var CoffeeParisLover = (function(_super) {
__extends(CoffeeParisLover, _super);
function CoffeeParisLover(name) {
CoffeeParisLover.__super__.constructor.call(this, name);
}
CoffeeParisLover.prototype.setAddress = function(street) {
return CoffeeParisLover.__super__.setAddress.call(this, "Paris", street);
};
return CoffeeParisLover;
})(CoffeeFrenchGuy);
var AugmentPerson = Object.augment(function() {
this.setAddress = function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
};
return AugmentPerson;
function AugmentPerson(name) {
this.name = name;
}
});
var AugmentFrenchGuy = AugmentPerson.augment(function(AugmentPerson, uber) {
var setAddress = uber.setAddress;
this.setAddress = function(city, street) {
setAddress.call(this, "France", city, street);
};
return AugmentFrenchGuy;
function AugmentFrenchGuy(name) {
AugmentPerson.call(this, name);
}
});
var AugmentParisLover = AugmentFrenchGuy.augment(function(AugmentFrenchGuy, uber) {
var setAddress = uber.setAddress;
this.setAddress = function(street) {
setAddress.call(this, "Paris", street);
};
return AugmentParisLover;
function AugmentParisLover(name) {
AugmentFrenchGuy.call(this, name);
}
});
Ext.define('ExtPerson', {
constructor: function(name) {
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
Ext.define('ExtChinaGuy', {
extend: 'ExtPerson',
constructor: function() {
this.callParent(arguments);
},
setAddress: function(city, street) {
this.callParent(['China', city, street]);
}
});
Ext.define('ExtBeiJingLover', {
extend: 'ExtChinaGuy',
constructor: function(name) {
this.callParent(arguments);
},
setAddress: function(street) {
this.callParent(['BeiJing', street]);
}
});
var OxyPerson = Oxy.define({
constructor: function(name) {
this.name = name;
},
setAddress: function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
});
var ChinaGuy = Oxy.define({
extend: OxyPerson,
constructor: function(name) {
OxyPerson.call(this, name)
},
setAddress: function(city, street) {
ChinaGuy.$super.setAddress.call(this, 'China', city, street);
}
});
var BeiJingLover = Oxy.define({
extend: ChinaGuy,
constructor: function(name) {
ChinaGuy.call(this, name);
},
setAddress: function(street) {
BeiJingLover.$super.setAddress.call(this, 'BeiJing', street);
}
});
var OxyPerson2 = Oxy.extend(Object, function() {
this.setAddress = function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
}
return OxyPerson2;
function OxyPerson2(name) {
this.name = name;
}
});
var ChinaGuy2 = Oxy.extend(OxyPerson2, function(OxyPerson2, parent) {
this.setAddress = function(city, street) {
parent.setAddress.call(this, 'China', city, street);
}
return ChinaGuy2;
function ChinaGuy2(name) {
OxyPerson2.call(this, name)
}
});
var BeiJingLover2 = Oxy.extend(ChinaGuy2, function(ChinaGuy2, parent) {
this.setAddress = function(street) {
parent.setAddress.call(this, 'BeiJing', street);
}
return BeijingLover2;
function BeijingLover2(name) {
ChinaGuy2.call(this, name);
}
});
var personProto = Person.prototype;
var personSetAddress = personProto.setAddress = function(country, city, street) {
this.country = country;
this.city = city;
this.street = street;
};
function Person(name) {
this.name = name;
}
var frenchProto = FrenchGuy.prototype = Object.create(personProto);
var frenchSetAddress = frenchProto.setAddress = function(city, street) {
personSetAddress.call(this, "France", city, street);
};
frenchProto.constructor = FrenchGuy;
function FrenchGuy(name) {
Person.call(this, name);
}
var parisProto = ParisLover.prototype = Object.create(frenchProto);
parisProto.setAddress = function(street) {
frenchSetAddress.call(this, "Paris", street);
};
parisProto.constructor = ParisLover;
function ParisLover(name) {
FrenchGuy.call(this, name);
}
</script>
Ready to run.
Test | Ops/sec | |
---|---|---|
JSFace |
| ready |
my.Class |
| ready |
John Resig Class |
| ready |
Klass |
| ready |
Classy |
| ready |
PTClass |
| ready |
CoffeeScript Classes |
| ready |
augment |
| ready |
Ext JS |
| ready |
OxygenJS |
| ready |
OxygenJS(augment style) |
| ready |
Vapor.js |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.