Skip to content

quarterpast/Estira

Repository files navigation

Livescript has a pretty sweet class system. Shame we can't use it in JS-land.

OR CAN WE.

Estira

const Base = require('estira');

var Foo = Base.extend({
  initialize: function(bar) {
    this.bar = bar;
  },
  frob: function(baz) {
    return this.bar + baz;
  }
});

var foo = new Foo("hello ");
foo.frob("world"); //⇒ "hello world"

API

Base = require('estira')

Base class with the bare minimal needed for inheritance. Extend it, it doesn't do much on its own.

Subclass = Superclass.extend(methods)

Returns a prototypal subclass of Superclass, inheriting Superclass's instance and class properties, extended with the object passed in. If methods contains a method called initialize, it is used as Subclass's constructor. If initialize is omitted, it delegates to the parent class' constructor.

Class.meta(methods)

Extends the "metaclass" of Class. Lets you add static methods, which may be inherited.

fn.super$

Refers to the parent class implementation of the function. Lets you call super methods like

var Superclass = Base.extend({
  quux: function() {
    return "hello";
  }
});
var Subclass = Superclass.extend(
  quux: function quux() {
    return quux.super$() + " world";
  }
);

Extending third-party classes

If you want to extend a class that doesn't derive from Base (e.g. EventEmitter), you can shoehorn estira onto it using Sub = Base.extend.call(EventEmitter, methods). Classes created this way can be further extended, and super$ calls still work.

Licence

MIT. © 2014 Matt Brennan.

About

Expose Livescript's class system to JavaScript

Resources

License

Stars

Watchers

Forks

Packages

No packages published