Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/gfarrell/jave

Jave (j-behave -> bejave -> jave) applies behaviour filters to bind javascript and DOM without additional scripting on page, thus decoupling layout and script.
https://github.com/gfarrell/jave

Last synced: about 1 month ago
JSON representation

Jave (j-behave -> bejave -> jave) applies behaviour filters to bind javascript and DOM without additional scripting on page, thus decoupling layout and script.

Awesome Lists containing this project

README

        

Jave, a jQuery Behaviour API
============================

Many libraries have plugins that are designed to automatically be applied to all elements of a certain attribute (normally a class). This sort of hooking is often done in a variety of ways, which makes having a lot of libraries doing this a bit inefficient (not to mention non-standard).

Jave aims to fix this by introducing a simple API for defining behaviours, which hook into a specific element attribute. These are then applied to all the elements at once after the DOM has loaded.

In short: Jave applies behaviour filters to bind javascript and DOM without additional scripting on page, thus decoupling layout and script.

Usage
-----

### Configuration

Jave's module definition expects "jquery" to be defined and loadable. In order for Jave to run smoothly, you should add the following line into your `main.js` (or whatever you call it) application root.

$.ready(function() { $.jave.init(); }); // run on DOM ready

This will run Jave when the DOM has loaded, which will automatically apply any defined behaviours to your elements. Jave takes some options:

$.jave.init(options);

* **selector** (string) defaults to "[data-behaviour]" *the selector to fetch elements with*
* **auto** (bool) defaults to true *whether or not to run Jave automatically*
* **root** (element) defaults to document.body *the root element to search in*

If **auto** is set to false, then you will have to run `$.jave.run($root);` manually, optionally specifying a root element (otherwise Jave will use the configured default).

### Defining behaviours

A behaviour is basically a function that normally triggers the instantiation and attachment of other classes (but can contain anything really). Behaviours are defined using `$.jave.define`, for example:

$.jave.define('my-behaviour', function($el, api) {
// do some stuff here
});

The first argument, the behaviour name, is the data-behaviour attribute that this behaviour will be associated with. The second argument is the behaviour itself.

All behaviours should have the function signature `function($el, api)`. The first argument is just the jQuery'd element, but the second argument is an instance of the JaveAPI applied to this element.

### Running Jave manually

If you have added elements to the DOM and want to add behaviours to them (e.g. for externally loaded HTML) then you can easily run Jave again on either the whole `document.body` (which won't be as fast) or on the parent element. Jave stores a list of which behaviours have been applied to each element, so you don't have to worry about something getting duplicated.

### The JaveAPI object

An instance of JaveAPI is attached to a particular element/behaviour combination and is used for retrieving specific values from the element.

Behaviours can have options defined in the HTML tag's attributes. These should take the form `data-my-behaviour-options`, as a serialised JSON object, or `data-my-behaviour-opt1`, which take individual options.

The JaveAPI can then be used to retrieve the values of these options, and to define default options if those aren't present. For example:

api.get('option_name'); // retrieves the value of data-my-behaviour-option_name
api.getAs('option_name', 'boolean'); // retrieves the value as a boolean

api.get('option_name', 'hello'); // default value is hello
api.getAs('option_name', 'boolean', true); // default value is true

### A working example

I have a validation class that I wish to apply to all inputs of a certain type. Each input can have specific validation criteria.

In HTML:



Submit


Alternatively, all the options can be represented as a JSON string:

My behaviour definition:

$.jave.define('validate', function($el, api) {
var v = new Validator($el, {
type: api.get('type'),
required: api.getAs('required', 'boolean', false)
});
// ...
});

Now, when the DOM is ready, my *validate* filter will be applied to all elements with the attribute `data-behaviour="validate"`.

Prerequisites
-------------

Jave is defined as an AMD module, with [http://www.requirejs.org](require.js) in mind. You can remove the module definition to have it as a simple class file, but I would recommend leaving it as is and just getting to grips with require.js. Jave requires a JSON library of your choice (as long as `JSON.parse()` exists).

It also requires jQuery, of course.

Inspiration
-----------

Jave was inspired by Anutron's Mootools-Behavior.