Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aaronpowell/knockoutjs-pre-parser
A pre-parser for KnockoutJS to use more convention-based discovery for the data binding
https://github.com/aaronpowell/knockoutjs-pre-parser
Last synced: about 1 month ago
JSON representation
A pre-parser for KnockoutJS to use more convention-based discovery for the data binding
- Host: GitHub
- URL: https://github.com/aaronpowell/knockoutjs-pre-parser
- Owner: aaronpowell
- License: mit
- Created: 2011-07-28T03:27:20.000Z (over 13 years ago)
- Default Branch: master
- Last Pushed: 2011-08-09T14:25:12.000Z (over 13 years ago)
- Last Synced: 2024-11-17T19:52:22.136Z (about 2 months ago)
- Language: JavaScript
- Homepage:
- Size: 181 KB
- Stars: 5
- Watchers: 4
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: License.txt
Awesome Lists containing this project
README
# KnockoutJS Pre-parser
I think that [KnockoutJS](http://knockoutjs.com) is a pretty cool library but I'm not a *huge* fan of how the `data-bind` attribute can begin to look in complex scenarios. I'm also not a huge fan of embedding a large amount of JavaScript in my HTML.
The goal of the KnockoutJS Pre-parser is to use more `data-*` attributes to better describe in HTML what you're intending to do.
# How's it work?
There are two ways which KnockoutJS Pre-parser works, either by parsing a provided binding schema or by using convention-based attributes.
## Binding Schema
In this mode the pre-parser will take a JavaScript object which represents the bindings that you wish to apply. These bindings will then be translated into something which KnockoutJS is able to understand and in turn bind against your ViewModel.
Currently the Binding Schema is only designed for working with very basic DOM structures, handling only the root level node. See the usages section for more information.
## Convention-based attirbutes
In this mode the pre-parser works by looking at a DOM element for the `data-ko-*` attributes and using those to build up a `data-bind` attribute.
For example it will take this:
First name: todo
Last name: todo
And produce this:
First name: todo
Last name: todo
The intent is for the `data-ko-*` attributes to describe in your HTML rather than having a single attribute with a JSON-*esq* string.
# Usage
To use the KockoutJS Pre-parser in your site you simply need to add a reference to it **after the KockoutJS file**.
## Using a Binding Schema
If you want to use a provided schema you need to do so by passing it as the second argument to your binding, like so:
var viewModel = { name: ko.observable('Aaron Powell') };
var schema = { text: 'name' };
var node = $('').get(0);
ko.applyBindings(viewModel, schema, node); //node.innerHTML === 'Aaron Powell'
## Using Convention-based attributesIf you want to use convention based attributes you just use KnockoutJS as you normally would, passing in a viewModel and an optional root node:
var viewModel = { fistName: ko.observable('Aaron'), lastName: ko.observable('Powell') };
var node = $('').get(0);
ko.applyBindings(viewModel, node); //the first span will have 'Aaron' and the second will have 'Powell'# Version
0.0.3