-
-
Notifications
You must be signed in to change notification settings - Fork 5
Template Cheat Sheet
This part will give you simple example about how to implement template.
// First parameter can be used as state/store that can be reactive
sf.model('modelName', function(My){
// Write model property here
My.hello = "world";
My.func = console.warn;
My.list = [1, 2, 3];
My.obj = {a:1, b:2, c:3};
});
If you're using sf.model
with name modelName
then you need to write HTML inside <sf-m name="modelName">
element. But only for the mustache template you can't directly use <sf-m>{{ hello }}</sf-m>
, and should be wrapped inside div
or span
.
<sf-m name="modelName">
<!-- Write template here -->
<div>hello {{ hello }}</div>
</sf-m>
Below should also be wrapped inside <sf-m>
.
<!-- One way binding -->
<input sf-into="intoModel"></input> <!-- Value into -> model -->
<input value="{{ fromModel }}"></input> <!-- Value from <- model -->
<!-- Two way binding -->
<input sf-bind="hello"></input> <!-- Value synced with <-> model -->
func
is function name registered on your model/component scope.
<a @click="func"></a>
<a @mouseup.left="func"></a>
<!-- You can also define the parameter -->
<a @click="func('hello', event)"></a>
<!-- With control button -->
<a @mouseup.ctrl.left="func"></a>
<!-- Keyboard key must be started with UpperCase-->
<input type="text" @keyup.ctrl.Enter="func"/>
<input type="text" @keyup.ArrowUp.once="func"/>
once, prevent, stop, passive, capture are available
<!-- Letters are case sensitive -->
<input type="text" @keyup.Z="func"/> UpperCase `Z`
<input type="text" @keyup.z="func"/> LowerCase `z`
Almost all event are supported like keyup, mousedown, touchup, scroll, etc.
Addional event: taphold, gesture, dragmove, filedrop
<div sf-each="val in list">
Hello {{ val }}
</div>
---
<div sf-each="key, val in obj">
Object[{{ key }}] = {{ val }};
</div>
If you want to use conditional on your element class/style you can use JavaScript's on the mustache {{ condition ? true : false }}
.
But for more complex usage, we can use full JavaScript with enveloped template:
<div>
{{@exec
var isChanged = (hello !== 'world');
// This will returned as new element
{[ <i>It was {{ isChanged ? '' : 'not' }} changed</i> ]}
var escapedHTML = "<b>I'm not bold</b>";
var realHTML = "<b>And I'm bold</b>";
/* Escaped HTML, this will not become bold */
{[ {{ escapedHTML}} ]}
/* Not escaped HTML (use carefully and avoid XSS!)
you can also return HTMLElement instead of string */
return realHTML;
}}
</div>
Template feature above is supported for model and component, and you can also run function inside mustache template.
- Framework
-
Installation
- Build Configuration
- Hot Reload
- Loader
- Model
-
Component
- Reserved Element
- Empty Shell
- Include external template
- Space
-
Views (Router)
- URI
- Static Template
- Language
- Element's query helper
- Events
- URL Request
- Window Extends