Skip to content

A model-agnostic live data binding template layer for the DOM.

License

Notifications You must be signed in to change notification settings

cruncher/sparky

Repository files navigation

Sparky

alt tag

Sparky is a live data binding templating engine that enhances the DOM with declarative tags and composeable templates, updating tags and rendering changes in batches at the browser frame rate for performance.

labs.cruncher.ch/sparky/

Latest build 2.2.1

Getting started

Clone the repo:

git clone git@github.com/cruncher/sparky.git
cd sparky/
git submodule update --init

Install node modules:

npm install

Build dist/sparky.js:

npm run build-nodeps    // Omit dependencies
npm run build           // Include dependencies

API

Sparky(selector)

Sparky takes this:

<div data-fn="find:'data'" class="user {[.|yesno:'active']}">
    <a class="thumb" style="background-image: url('{[avatar]}')">{[name]}</a>
</div>

window.data = {
    avatar: '/username/avatar.png',
    name: 'Godfrey'
};

Sparky('.user');

And renders this:

<div data-fn="scope:'data'" class="user active">
    <a class="thumb" style="background-image: url('/username/avatar.png')">Godfrey</a>
</div>

The Sparky constructor takes a DOM fragment or a DOM node or a selector.

var fragment = document.createDocumentFragment();
Sparky(fragment);

var node = document.querySelector('.user');
Sparky(node);

Sparky('.user');

And an optional second argument, scope.

Sparky('.user', {
    avatar: '/username/avatar.png',
    name: 'Godfrey'
});

A sparky object is a pushable stream of data objects that are mapped through functions declared in the sparky-fn attribute and then rendered to tags.