Object.create() vs. constructor vs. object literal

JavaScript performance comparison

Revision 86 of this test case created

Preparation code

<script>
  var o;

  var Obj = function() {
   this.p = 1;
  };

Obj.prototype = {
        method1: function(){},
        method2: function(){},
        method3: function(){},
        method4: function(){},
        method5: function(){},
        method6: function(){},
        method7: function(){},
        method8: function(){},
        method9: function(){},
        method10: function(){},
        method11: function(){},
        method12: function(){},
        method13: function(){},
        method14: function(){},
        method15: function(){},
        method16: function(){},
        method17: function(){},
        method18: function(){},
        method19: function(){},
        method20: function(){}
}
 
  var propObj = {
   p: {
    value: 1,
        method1: function(){},
        method2: function(){},
        method3: function(){},
        method4: function(){},
        method5: function(){},
        method6: function(){},
        method7: function(){},
        method8: function(){},
        method9: function(){},
        method10: function(){},
        method11: function(){},
        method12: function(){},
        method13: function(){},
        method14: function(){},
        method15: function(){},
        method16: function(){},
        method17: function(){},
        method18: function(){},
        method19: function(){},
        method20: function(){}
   }
  };
 
  var protoObj = {p: 1};
 
  function F() {}

  function object(o) {
      F.prototype = o;
      return new F();
  }
</script>

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

Testing in unknown unknown
Test Ops/sec
Object.create() using in-place property object
o = Object.create(Object.prototype, {
 p: {
  value: 1
 }
});
pending…
Object.create() using pre-defined property object
o = Object.create(Object.prototype, propObj);
pending…
Constructor function
o = new Obj();
pending…
Object.create() using in-place prototype object
o = Object.create({p: 1});
pending…
Object.create() using pre-defined prototype object
o = Object.create(protoObj);
pending…
Crockford method using in-place prototype object
o = object({p: 1});
pending…
Crockford method using pre-defined prototype object
o = object(protoObj);
pending…
Object literal
o = {p: 1};
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:

0 comments

Add a comment