Clazzy
A cross platform JavaScript library that provides a classical interface to prototype inheritance using a simple DSL inspired by Ruby.
Usage
Creating a class
var Foo = Clazzy.create(
{
initialize : function ()
{
this.foo = 'foo';
},
bar : function ()
{
return 'bar';
},
baz : function (baz)
{
return baz;
},
static :
{
qux : function ()
{
return 'qux';
}
}
});
var foo = new Foo();
foo.foo;
foo.bar();
foo.baz('baz');
Foo.qux();
Note: Instance properties can be defined in the definition, however their inital value should be set in the constructor.
Creating a class that extends another class
var Bar = Clazzy.create(
{
extend : Foo,
initialize : function ()
{
this.super();
this.corge = 'corge';
},
baz : function ()
{
return 'bar';
},
baz : function (baz)
{
return 'super ' + this.super(baz);
}
});
var bar = new Bar();
bar.foo;
bar.corge;
bar.bar();
bar.baz('qux');
Bar.qux();
Note:
- Static methods are not inherited.
- If a method overrides one of its base class methods, you can invoke the overridden method through the use of the
super
method.
Creating a class that includes another class
Clazzy provides a method of code reuse called includes. Behaving similarly to Ruby's mixins and PHP's traits, they enable a developer to reuse sets of methods freely in several independent classes living in different class hierarchies.
var Baz = Clazzy.create(
{
include : [Foo],
moo : function ()
{
return 'moo';
}
});
var baz = new Baz();
baz.foo;
baz.bar();
baz.baz('baz');
baz.moo();
Baz.qux();
Note:
- Static methods are not included.
- The super method, when invoked from an included method, does not reference the hierarchy of the class it's included in.
- The precedence order is that an inherited member from a base class is overridden by an included member, which in turn are both overridden by a member from the current class.
Getting started
Node
Clazzy is available through the Node Package Manager, so you can install like so:
npm install clazzy
and bring into your code like so:
var Clazzy = require('clazzy');
Browser
To use Clazzy in a browser envrionment, just use a script tag like so:
<script type="text/javascript" src="path/to/Clazzy.js"></script>
To remove Clazzy from the global namespace, you can use Clazzy.noConflict()
, like so:
Namespace.Clazzy = Clazzy.noConflict();
Development
Grunt is used to handle the build process for Clazzy. To perform a full build, use the build
task:
grunt build
which is just an alias for the default
task:
grunt
To only check code quality and/or run unit tests use the test
task:
grunt test
License
Clazzy is released under the MIT License.