bamboo
A model library for client side javascript making it easy to load and persist javascript-object like data structures to/from a backend (typically over ajax) and use them in view/template bindings.
overview
The idea behind bamboo is that loading and persisting basic object-ish resources (Plain Old Javascript Objects) should be easy and work well within view/template binding libraries.
To accomplish this, you define a basic schema for your models and provide a sync function to use. The schema is used to define which properties will emit change events when changed. This plays nicely with view/template libraries that can bind to such events.
Complete documentation can be found on the wiki and a simple getting started example is outlined below.
getting started
Setup a basic model using a schema
Before using the model to load or save resources, you must define the properties of the model. This schema will specify how the model reacts when you set these properties.
var Model = require('bamboo/model');
var ajax = require('bamboo/sync/ajax');
var Post = Model({
title: String,
author: {
name: String,
email: String
}
}, { sync: ajax });
Set a base url
This will be the basepath for url resources. Typically it will be the plural
of whatever noun used for the model.
Post.url_root = '/posts';
See the sync wiki page for an overview of how these routes are used.
instantiate a new model
Create a Post instance on the client and persist to the server.
var post = Post();
post.title = 'my first post';
post.author = {
name = 'Edgar Poe';
};
post.author.name = 'Fannie Poe';
See the Emitter wiki page to learn more about how models emit events. All models are instances of an event emitter.
Persist the model
Bamboo persists and loads all models via a configured sync
function. Bamboo ships with a working ajax function you can use, or you can wrap your favorite ajax library. See the options wiki page for details.
In our example post, we used the bamboo provided ajax sync
function to persist our models over ajax. Bamboo avoids using globals or state and leaves this up to you to dictate how to build your app; You will need to specify the sync option for every Model you build and wish to persist (not every instance).
post.save(function(err) {
});
See the options wiki page for details on writing a sync function.
reload a persisted model
Our first model has been persisted to the server; we could load it on another page assuming we know the id of the post we want.
Post.get(id, function(err, post) {
});
Or, if we need to get a list of posts
Post.find(function(err, posts) {
});
documentation
See the wiki pages and examples for more exotic uses and how a post can contain an array of comments.
install
npm install bamboo
view/template libraries
Bamboo can play nice with many view/template libraries. Some cool ones to consider:
Using bamboo with another view/template lib? Let me know!
inspiration
Bamboo draws heavy inspiration from backbone models.
license
MIT