ractive-ractive
Experimental ractive adaptor for ractive objects. This makes it possible to use template-less Ractive objects as models.
Find more Ractive.js plugins at docs.ractivejs.org/latest/plugins
Note for v0.x users:
v1.0.0 changes the behavior of doing
require('ractive-ractive')
(eg, in Browserify). See the changelog for upgrade instructions.
Example
Ractivedefaultsadapt; parent = ;user = ; parent;
Changes in children are propagated to the parent:
user;parent //=> "Jake"
Changes in the parent are propagated to the children:
parent;user //=> "Matt"
Features
Everything you'd expect to work will work.
- bi-directional propagation
- observers
- templates
- computed properties
However, these things are not supported, but may be in the future:
- circular dependencies (an error will be thrown)
- events (see ractive#1249)
Wrap events
It will trigger a few events:
wrap
- called when the instance is set as an attribute of another instanceunwrap
- called when the instance has been unset from its parentwrapchild
- called when the instance gets an Ractive attribute setunwrapchild
- called when the instance gets an Ractive attribute unset
To illustrate:
parent = ;child = ; parent;// triggers `wrap(parent, 'x')` on child// triggers `wrapchild(child, 'x')` on parent parent;// triggers `unwrap(parent, 'x')` on child// triggers `unwrapchild(child, 'x')` on parent
Usage
ractive-ractive is available via npm.
$ npm install --save ractive-ractive
In CommonJS:
RactiveadaptorsRactive = ;Ractivedefaultsadapt = 'Ractive';
Without module loaders, the adaptor is available as "Ractive"
under Ractive.adaptors.Ractive
.
Credits
Hat tip to the original Ractive adaptor from @Rich-Harris. (src)
Thanks
ractive-ractive © 2014+, Rico Sta. Cruz. Released under the MIT License.
Authored and maintained by Rico Sta. Cruz with help from contributors (list).
ricostacruz.com · GitHub @rstacruz · Twitter @rstacruz