Skip to content

Latest commit

 

History

History
64 lines (48 loc) · 1.19 KB

README.md

File metadata and controls

64 lines (48 loc) · 1.19 KB

Knockoff

Reactive data binding component with syntax partially compatible with knockoutjs

Installation

$ component install karlbohlmark/knockoff

Basic example

Given a template node:

<form id="my-template-root" action="/action">
    <input data-bind="value: firstname">
</form>

Bind the (plain javascript) model object to the dom node, with two-way binding

var knockoff = require('knockoff')

var el = document.querySelector('#my-template-root')

model = {
    firstname: 'Karl'
}

knockoff(el, model)

Reactive example

Given a template node:

<div class="container">
    <ul>
        <li data-bind="foreach: user in users">
        <span data-bind="text: user.name"></span>
        </li>
    </ul>
</div>

Bind the change event emitting model object to the dom node

var knockoff = require('knockoff')
var ObservableCollection = require('observable-collection')
var users = ObservableCollection([{
    name: "Regina Spektor"
}])
var el = document.querySelector('.container')

knockoff(el, {
    users: users
})

users.push({
    name: 'Amanda Palmer'
}) // A `li` element is created to reflect the changes in the collection

License

MIT