<tag-name>
<div>
hello {name}
</div>
this.name = opts.name
</tag-name>
<tag-name>
<script>riot.mount('*')</script>
<script>riot.mount('tag-name')</script>
<script>riot.mount('tag-name', { title: 'my app', ... })</script>
Expressions
{value}
{value || 'its a js expression'}
<input checked={null}>
<p class={ selected: true }>
Loops
<li each={movies}>{title}</li>
Conditional
<div if={error}>
<div show={error}> /* show using display: '' */
<div hide={error}> /* hide using display: none */
Events
<button onclick={go}>
this.go = function (e) { ... }
API
this.update()
this.update({ data: 'hi' }
this.unmount()
this.unmount(true)
riot.update()
Nesting
<my-tag>
<child></child>
var child = this.tags.child
</my-tag>
Names
<my-tag>
<child name='xyz'></child>
var child = this.tags.xyz
</my-tag>
Nested HTML
<yield/>
Yield to/from
<post>
<yield to='title'>Hello</yield>
<yield to='body'>Hey there world</yield>
</post>
<post>
<yield from='title'/>
<yield from='body'/>
</post>
Router
riot.route('customers/*/edit', (id) => {
})
riot.route('customers/234/edit')
riot.route.start()
riot.route.start(true)
Lifecycle
this.on('before-mount', function() {
})
this.on('mount', function() {
})
this.on('update', function() {
})
this.on('updated', function() {
})
this.on('before-unmount', function() {
})
this.on('unmount', function() {
})
this.on('all', function(eventName) {
console.info(eventName)
})