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
<!-- JQURY -->
<script src="http://code.jquery.com/jquery-2.0.0.min.js"></script>
<!-- ANGULAR -->
<script src="http://code.angularjs.org/1.1.5/angular.min.js" ng:autobind></script>
<script>
var Ctrl=function($scope){
$scope.data=[];
}
</script>
<div ng:app>
<ul ng-controller="Ctrl" id="angList" >
<li ng-repeat="item in data">{{item}}</li>
</ul>
<script>
var SetANG= function(data){
$('#angList').scope().data=data;
$('#angList').scope().$apply(function(){});
};
</script>
<!-- ANGULAR Update -->
<script>
var CtrlUpdate=function($scope){
$scope.data=[];
}
</script>
<ul ng-controller="CtrlUpdate" id="angListUpdate" >
<li ng-repeat="item in data">{{item}}</li>
</ul></div>
</div>
<script>
var SetANGUpdate= function(data){
$('#angListUpdate').scope().data=data;
$('#angListUpdate').scope().$apply(function(){});
};
</script>
<!-- EXT -->
<script src="http://docs.sencha.com/extjs/4.2.1/extjs/ext-all.js"></script>
<div id="extme"></div>
<script>
var EXTData= [ ];
var store = Ext.create('Ext.data.Store', {
storeId:'employeeStore',
fields:['name' ],
data: EXTData
});
Ext.create('Ext.grid.Panel', {
title: 'Employees',
store: Ext.data.StoreManager.lookup('employeeStore'),
columns: [
{ dataIndex: 'name' }],
renderTo: Ext.getBody()
});
var SetEXT=function (data){
store.removeAll();
store.add(data);
}
var ANG50ID=[];
for (var i=0; i<50;i++){
ANG50ID.push('ITEM');
};
var EXT50ID=[];
for (var i=0; i<50;i++){
EXT50ID.push({name:'ITEM'});
};
var KE50ID=[];
for (var i=0; i<50;i++){
KE50ID.push({name:'ITEM'});
};
var ANG100ID=[];
for (var i=0; i<100;i++){
ANG100ID.push('ITEM');
};
var EXT100ID=[];
for (var i=0; i<100;i++){
EXT100ID.push({name:'ITEM'});
};
var KE100ID=[];
for (var i=0; i<100;i++){
KE100ID.push({name:'ITEM'});
};
var ANG1000ID=[];
for (var i=0; i<1000;i++){
ANG1000ID.push('ITEM');
};
var EXT1000ID=[];
for (var i=0; i<1000;i++){
EXT1000ID.push({name:'ITEM'});
};
var KE1000ID=[];
for (var i=0; i<1000;i++){
KE1000ID.push({name:'ITEM'});
};
</script>
<script src="http://cdn.kendostatic.com/2013.1.514/js/kendo.all.min.js"</script>
<ul data-template="ul-template" data-bind="source: products" style="display:none">
</ul>
<script id="ul-template" type="text/x-kendo-template">
<li data-bind="text: this"></li>
</script>
<script>
var viewModel = kendo.observable({
products: []
});
kendo.bind($("ul"), viewModel);
function SetKE(data) {
viewModel.set('products',data);
};
</script>
SetANG([]);
SetEXT([]);
//SetKE([]);
//SetANGUpdate(ANG100ID);
Ready to run.
Test | Ops/sec | |
---|---|---|
Angular 0-50 Items |
| ready |
ExtJS 0-50 Items |
| ready |
Angular 0-100 Items |
| ready |
ExtJS 0-100 Items |
| ready |
Angular 0-1000 Items |
| ready |
ExtJS 0-1000 Items |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.