Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is __proto__ type Surrogate in JavaScript?

Using Backbone.js, I console logged an instance of a Backbone.View.extend({}) to find the __proto__ type to be Surrogate.

var view = Backbone.View.extend({});
console.log(view);

This resulted in an object with type Surrogate for its __proto__

__proto__: Surrogate

What is Surrogate?

like image 814
AndrewHenderson Avatar asked Dec 20 '12 01:12

AndrewHenderson


1 Answers

Surrogate is a "helper" class in Backbone to set up prototype chaining. Check out the source code:

  // Helper function to correctly set up the prototype chain, for subclasses.
  // Similar to `goog.inherits`, but uses a hash of prototype properties and
  // class properties to be extended.
  var extend = function(protoProps, staticProps) {
    var parent = this;
    var child;

    // The constructor function for the new subclass is either defined by you
    // (the "constructor" property in your `extend` definition), or defaulted
    // by us to simply call the parent's constructor.
    if (protoProps && _.has(protoProps, 'constructor')) {
      child = protoProps.constructor;
    } else {
      child = function(){ parent.apply(this, arguments); };
    }

    // Add static properties to the constructor function, if supplied.
    _.extend(child, parent, staticProps);

    // Set the prototype chain to inherit from `parent`, without calling
    // `parent`'s constructor function.
    var Surrogate = function(){ this.constructor = child; };
    Surrogate.prototype = parent.prototype;
    child.prototype = new Surrogate;

    // Add prototype properties (instance properties) to the subclass,
    // if supplied.
    if (protoProps) _.extend(child.prototype, protoProps);

    // Set a convenience property in case the parent's prototype is needed
    // later.
    child.__super__ = parent.prototype;

    return child;
  };
like image 181
Lukas Avatar answered Oct 14 '22 23:10

Lukas