Guide
Essentials
- Installation
- Introduction
- The Kdu Instance
- Template Syntax
- Computed Properties and Watchers
- Class and Style Bindings
- Conditional Rendering
- List Rendering
- Event Handling
- Form Input Bindings
- Components Basics
Components In-Depth
- Component Registration
- Props
- Custom Events
- Slots
- Dynamic & Async Components
- Handling Edge Cases
Transitions & Animation
- Enter/Leave & List Transitions
- State Transitions
Reusability & Composition
- Mixins
- Custom Directives
- Render Functions & JSX
- Plugins
- Filters
Tooling
- Single File Components
- TypeScript Support
- Production Deployment
Scaling Up
- Routing
- State Management
- Server-Side Rendering
- Security
Internals
- Reactivity in Depth
Migrating
- Migration to Kdu 2.7
Meta
- Meet the Team
Template Syntax
Kdu.js uses an HTML-based template syntax that allows you to declaratively bind the rendered DOM to the underlying Kdu instance’s data. All Kdu.js templates are valid HTML that can be parsed by spec-compliant browsers and HTML parsers.
Under the hood, Kdu compiles the templates into Virtual DOM render functions. Combined with the reactivity system, Kdu is able to intelligently figure out the minimal number of components to re-render and apply the minimal amount of DOM manipulations when the app state changes.
If you are familiar with Virtual DOM concepts and prefer the raw power of JavaScript, you can also directly write render functions instead of templates, with optional JSX support.
Interpolations
Text
The most basic form of data binding is text interpolation using the “Mustache” syntax (double curly braces):
|
The mustache tag will be replaced with the value of the msg
property on the corresponding data object. It will also be updated whenever the data object’s msg
property changes.
You can also perform one-time interpolations that do not update on data change by using the k-once directive, but keep in mind this will also affect any other bindings on the same node:
|
Raw HTML
The double mustaches interprets the data as plain text, not HTML. In order to output real HTML, you will need to use the k-html
directive:
|
Using mustaches: {{ rawHtml }}
Using k-html directive:
The contents of the span
will be replaced with the value of the rawHtml
property, interpreted as plain HTML - data bindings are ignored. Note that you cannot use k-html
to compose template partials, because Kdu is not a string-based templating engine. Instead, components are preferred as the fundamental unit for UI reuse and composition.
Dynamically rendering arbitrary HTML on your website can be very dangerous because it can easily lead to XSS vulnerabilities. Only use HTML interpolation on trusted content and never on user-provided content.
Attributes
Mustaches cannot be used inside HTML attributes. Instead, use a k-bind
directive:
|
In the case of boolean attributes, where their mere existence implies true
, k-bind
works a little differently. In this example:
|
If isButtonDisabled
has the value of null
, undefined
, or false
, the disabled
attribute will not even be included in the rendered <button>
element.
Using JavaScript Expressions
So far we’ve only been binding to simple property keys in our templates. But Kdu.js actually supports the full power of JavaScript expressions inside all data bindings:
|
These expressions will be evaluated as JavaScript in the data scope of the owner Kdu instance. One restriction is that each binding can only contain one single expression, so the following will NOT work:
|
Template expressions are sandboxed and only have access to a whitelist of globals such as Math
and Date
. You should not attempt to access user-defined globals in template expressions.
Directives
Directives are special attributes with the k-
prefix. Directive attribute values are expected to be a single JavaScript expression (with the exception of k-for
, which will be discussed later). A directive’s job is to reactively apply side effects to the DOM when the value of its expression changes. Let’s review the example we saw in the introduction:
|
Here, the k-if
directive would remove/insert the <p>
element based on the truthiness of the value of the expression seen
.
Arguments
Some directives can take an “argument”, denoted by a colon after the directive name. For example, the k-bind
directive is used to reactively update an HTML attribute:
|
Here href
is the argument, which tells the k-bind
directive to bind the element’s href
attribute to the value of the expression url
.
Another example is the k-on
directive, which listens to DOM events:
|
Here the argument is the event name to listen to. We will talk about event handling in more detail too.
Dynamic Arguments
New in 2.6.0+
Starting in version 2.6.0, it is also possible to use a JavaScript expression in a directive argument by wrapping it with square brackets:
|
Here attributeName
will be dynamically evaluated as a JavaScript expression, and its evaluated value will be used as the final value for the argument. For example, if your Kdu instance has a data property, attributeName
, whose value is "href"
, then this binding will be equivalent to k-bind:href
.
Similarly, you can use dynamic arguments to bind a handler to a dynamic event name:
|
In this example, when eventName
‘s value is "focus"
, k-on:[eventName]
will be equivalent to k-on:focus
.
Dynamic Argument Value Constraints
Dynamic arguments are expected to evaluate to a string, with the exception of null
. The special value null
can be used to explicitly remove the binding. Any other non-string value will trigger a warning.
Dynamic Argument Expression Constraints
Dynamic argument expressions have some syntax constraints because certain characters, such as spaces and quotes, are invalid inside HTML attribute names. For example, the following is invalid:
|
The workaround is to either use expressions without spaces or quotes, or replace the complex expression with a computed property.
When using in-DOM templates (i.e., templates written directly in an HTML file), you should also avoid naming keys with uppercase characters, as browsers will coerce attribute names into lowercase:
|
Modifiers
Modifiers are special postfixes denoted by a dot, which indicate that a directive should be bound in some special way. For example, the .prevent
modifier tells the k-on
directive to call event.preventDefault()
on the triggered event:
|
You’ll see other examples of modifiers later, for k-on
and for k-model
, when we explore those features.
Shorthands
The k-
prefix serves as a visual cue for identifying Kdu-specific attributes in your templates. This is useful when you are using Kdu.js to apply dynamic behavior to some existing markup, but can feel verbose for some frequently used directives. At the same time, the need for the k-
prefix becomes less important when you are building a SPA, where Kdu manages every template. Therefore, Kdu provides special shorthands for two of the most often used directives, k-bind
and k-on
:
k-bind
Shorthand
|
k-on
Shorthand
|
They may look a bit different from normal HTML, but :
and @
are valid characters for attribute names and all Kdu-supported browsers can parse it correctly. In addition, they do not appear in the final rendered markup. The shorthand syntax is totally optional, but you will likely appreciate it when you learn more about its usage later.